How to understand Vue's simple state management store mode

How to understand Vue's simple state management store mode

Overview

The implementation idea of ​​the store state management mode is very simple, which is to define a store object with a state attribute to store shared data and methods to operate these shared data. In the component, store.state shared data is used as part or all of data. When changing the shared data in the store.state object, the interface provided by the store must be called to change the shared data.

The following is a simple todo-list demo to introduce the store state management mode.

1. Define store.js

//store.js
export const store = {
    state: {
        todos:
            {text: 'Write Chinese homework', done: false},
            {text: 'Do math test', done: false}
        ]
    },
    addTodo(str){
        const obj = {text: str, done: false}
        this.state.todos.push(obj)
    },
    setDone(index){
        this.state.todos[index].done = true
    }
}

2. Components using store.js

//A.vue
<template>
    <div class="A">
        I am component A<ul>
           <li v-for="(todo,index) in todos" 
           :key="index" :class="todo.done?'done':''" @click="setDone(index)">
           {{todo.text}}
           </li>
       </ul>
    </div>
</template>

<script>
import {store} from '../store/store.js'
export default {
    name: 'A',
    data(){
        return store.state
    },
    methods: {
        setDone(index){
            store.setDone(index)
        }
    }
}
</script>

<style scoped>
.A{
    background: red;
    color: white;
    padding: 20px;
}
.A li.done{
    background: green;
}
</style>
//B.vue
<template>
    <div class="B">
        <div>
            I am component B, enter the task in the input box below and add the task in component A</div>
        <input type="text" v-model="text">
        <button @click="addTodo">add todo</button>
    </div>
</template>

<script>
import {store} from '../store/store.js'
export default {
    name: 'B',
    data(){
        return {
            text: ''
        }
    },
    methods:{
        addTodo(){
            if(this.text){
                store.addTodo(this.text)
            }
        }
    }
}
</script>

<style scoped>
.B{
    background: yellow;
    padding: 20px;
}
</style>
//App.vue
<template>
  <div id="app">
    <A />
    <B />
  </div>
</template>

<script>

import A from './components/A.vue'
import B from './components/B.vue'

export default {
  name: 'App',
  components:
    A,
    B
  }
}
</script>

3. Achieve results

It can be seen that the data displayed in component A is added and modified in component B, which is data communication through data sharing. The simple store mode is used in this way.

The above is the details of how to understand the store mode of Vue simple state management. For more information about the store mode of Vue simple state management, please pay attention to other related articles on 123WORDPRESS.COM!

You may also be interested in:
  • How to use provide to implement state management in Vue3
  • Vue front-end development auxiliary function state management detailed example
  • The practical process of login status management in the vuex project
  • Quickly master how to get started with Vuex state management in Vue3.0
  • Application of mapState idea in vuex
  • How to use vuex in Vue project
  • Use of vuex namespace
  • Vue state management: using Pinia instead of Vuex

<<:  Cause Analysis and Solution of I/O Error When Deleting MySQL Table

>>:  Ubuntu Basic Tutorial: apt-get Command

Recommend

Analysis of three parameters of MySQL replication problem

Table of contents 01 sql_slave_skip_counter param...

Nginx dynamic and static separation implementation case code analysis

Separation of static and dynamic Dynamic requests...

MySQL 8.0.18 uses clone plugin to rebuild MGR implementation

Assume that a node in the three-node MGR is abnor...

Solve the problem of inconsistent MySQL storage time

After obtaining the system time using Java and st...

Talk about nextTick in Vue

When the data changes, the DOM view is not update...

MySQL 8.0.12 installation and configuration method graphic tutorial

Record the installation and configuration method ...

Tutorial on installing VMWare15.5 under Linux

To install VMWare under Linux, you need to downlo...

How to view version information in Linux

How to view version information under Linux, incl...

jQuery implements a simple carousel effect

Hello everyone, today I will share with you the i...

When backing up files in Centos7, add the backup date to the backup file

Linux uses files as the basis to manage the devic...

Talk about implicit conversion in MySQL

In the course of work, you will encounter many ca...

Detailed explanation of the murder caused by a / slash in Nginx proxy_pass

background An nginx server module needs to proxy ...