zoukankan      html  css  js  c++  java
  • vuex-- Vue.的中心化状态管理方案(vue 组件之间的通信简化机制)

    vuex-- Vue.的中心化状态管理方案(vue 组件之间的通信简化机制)

    如果你在使用 vue.js , 那么我想你可能会对 vue 组件之间的通信感到崩溃 。vuex就是为了解决组件通信问题的。

    组件通信的本质其实就是在组件之间传递数据或组件的状态(这里将数据和状态统称为状态),但可以看到如果我们通过最基本的方式来进行通信,一旦需要管理的状态多了,代码就会变得十分臃肿和庞大。对所有状态的管理便会显得力不从心,因此,vuex出现了,他就是帮助我们把公用的状态全抽出来放在vuex的容器中,然后根据一定的规则来进行管理。

    1.安装

    npm install vuex --save-dev
    

    2.使用

    一、安装完成之后,在main.js中引入,并注册store:这样我们就能通过this.$store来获得这个容器了

    main.js代码:

    import Vue from 'vue'
    import App from './App'
    import router from './router'
    import Vuex from 'vuex'
    import store from './vuex/store'
    
    Vue.use(Vuex)
    
    Vue.config.productionTip = false
    
    /* eslint-disable no-new */
    new Vue({
      el: '#app',
      router,
      store,
      template: '<App/>',
      components: { App }
    })
    

    二、在src目录下创建vuex目录,然后在vuex目录下创建store.js,用于存放所有的状态(改变的数据)

    store.js代码:

    import Vue from 'vue'
    import Vuex from 'vuex'
    
    Vue.use(Vuex)
    
    const store = new Vuex.Store({
      state: {
        userName : 'ghostwu'
      }
    })
    
    export default store
    

    在state存储了一个状态userName

    三、将状态中的数据渲染到组件中

    在components下面新建一个组件Main.vue,代码如下

    <template>
        <div>
            <h3>{{myName}}</h3>
        </div>
    </template>
    <script>
        export default {
            name : "Main",
            computed : {
                myName (){
                    return this.$store.state.userName;
                }
            }
        }
    </script>
    

    通过一个计算属性获取到存储在全局容器store中state保存的状态值

    四,在App.vue中引入组件Main.vue

    App.vue代码:

    <template>
      <div id="app">
        <Mainc></Mainc>
      </div>
    </template>
    
    <script>
    import Mainc from './components/Main.vue';
    export default {
      name: 'app',
      components : {
        Mainc
      }
    }
    </script>
    

    这个时候,就能看见在页面上把store容器中 state的userName的值读取出来了, 如果修改userName的值,页面上也会发生变化

    五、,我们通过一些交互来改变状态,看下组件是否能收到state的值

    在components组件下新建一个Header.vue组件,代码如下:

    <template>
        <div>
            <input type="text" v-model="msg" />
            <input type="button" v-on:click="setName" value="点我" />
        </div>
    </template>
    <script>
        export default {
            name : 'Header',
            data(){
                return {
                    msg : ''
                }
            },
            methods : {
                setName(){
                    this.$store.state.userName = this.msg;
                }
            }
        }
    </script>

    App.vue引入组件Header

    App.vue代码如下:

    <template>
      <div id="app">
        <Headerc></Headerc>
        <Mainc></Mainc>
      </div>
    </template>
    
    <script>
    import Headerc from './components/Header.vue';
    import Mainc from './components/Main.vue';
    export default {
      name: 'app',
      components : {
        Headerc,
        Mainc
      }
    }
    </script>
    

    当我点击按钮的时候,改变state中useName的值,Main组件中的state.userName的值也会跟着更新,这种改变方式很好理解,接下来我们看下vuex推荐的状态改变方式

    六、vuex推荐的状态改变方法

    在store.js中新建一个mutations,存放被修改的状态

    import Vue from 'vue'
    import Vuex from 'vuex'
    
    Vue.use(Vuex)
    
    const store = new Vuex.Store({
      state: {
        userName : 'ghostwu'
      },
      mutations : {
        showUserName( state, msg ){
          state.userName = msg;
        }
      }
    })
    
    export default store

    其中第一个参数 state 就是 $store.state,第二个参数 msg 需要另外传入,这个参数我们通过Header.vue的点击事件中的方法来传递

    Header.vue代码:

    <template>
        <div>
            <input type="text" v-model="msg" />
            <input type="button" v-on:click="setName" value="点我" />
        </div>
    </template>
    <script>
        export default {
            name : 'Header',
            data(){
                return {
                    msg : ''
                }
            },
            methods : {
                setName(){
                    this.$store.commit( 'showUserName', this.msg );
                }
            }
        }
    </script>
    

    $store.commit 把this.msg的值提交给showUserName。state就收到了改变的状态了,这就是一个vuex最基本的用法和作用

    作者:ghostwu, 出处:http://www.cnblogs.com/ghostwu 
  • 相关阅读:
    PrintWriter write与println方法的区别
    java线程之一 单线程
    Android系列之ListView实现分页和类似异步加载效果(转载)
    Failed to fetch URL http://dlssl.google.com/android/repository/addons_list
    java rpc 综述(上)
    横竖屏切换时候Activity的生命周期
    【转载】C# 大数相乘
    ASP.NET 2.0 中使用PreviousPage的强类型属性
    人生一世
    SQL 中的indexof函数CHARINDEX
  • 原文地址:https://www.cnblogs.com/s313139232/p/9203459.html
Copyright © 2011-2022 走看看