zoukankan      html  css  js  c++  java
  • vuex使用

    一、src目录下面新建一个vuex文件夹

    二、vuex文件夹新建一个store.js文件

    三、安装vuex

    npm install vuex --save
    

    四、在刚才创建的store.js引入vue 引入vuex并use vuex

    import Vue form 'vue'
    import Vuex form 'vuex'
    Vue.use(Vuex)
    

    五、定义数据 state

    /* state在vuex中用于存储数据*/
    
    var state={
        count=1,
    }
    
    
    

    六、定义方法 mutations

    mutations 里面放的是方法,方法主要用于改变state里面的数据

    var mutations ={
        inCount(){
            ++state.count;
        }
    }
    

    七、暴露实例

    const store =new Vuex.Store({
        state,
        mutations
    })
    export default store;
    
    
    

    八、组件里面使用vuex

    1. 引入store
    import store form '../vuex/store.js'
    
    1. 注册
    export defalut {
        data (){
            return {
                msg:'eeee'
            }
        },
        store,
        methods:{
            inCount(){
                //改变 vuex store里面的数据
                this.$store.commint('inCount'); //触发state里面的数据
            }
        }
    }
    
    

    3.获取state里面的数据

    this.$store.state.数据
    
    

    4.触发mutations 改变state里面的数据

    this.$store.state.commit('inCount');
    
    

    getters

    类似计算属性。改变state里面的count数据的时候会触发getters里面的方法,获取新的值

    getters:{
        doneTodoCount:(state,getters) =>{
            return getters.doneTodos.length
        }
    }
    
    
    

    store.js配置

    import Vue from 'vue'
    import Vuex from 'vuex'
    
    Vue.use(Vuex);
    
    
    /*1.state在vuex中用于存储数据*/
    var state={
    
        count:1,
        list:[]
    }
    
    /*2.mutations里面放的是方法,方法主要用于改变state里面的数据
    */
    var mutations={
    
        incCount(){
    
            ++state.count;
        },
        addList(state,data){
    
            state.list = data;
        }
    }
    
    /*3、优点类似计算属性 ,  改变state里面的count数据的时候会触发 getters里面的方法 获取新的值 (基本用不到)*/
    
    
    var getters= {
       
        computedCount: (state) => {
            return state.count*2
        }
    }
    
    
    
    
    4. action
    
    Action 类似于 mutation,不同在于:
    
    Action 提交的是 mutation,而不是直接变更状态。
    Action 可以包含任意异步操作。
    actions不能直接修改全局变量,需要调用commit方法来触发mutation中的方法
    */
    
    
    var actions= {
        incMutationsCount(context) {    /*因此你可以调用 context.commit 提交一个 mutation*/
          
          
            context.commit('incCount');    /*执行 mutations 里面的incCount方法 改变state里面的数据*/
    
    
        }
    }
    
    
    
    //vuex  实例化 Vuex.store   注意暴露
    const store = new Vuex.Store({
        state,
        mutations,
        getters,
        actions
    })
    
    
    export default store;
    

    vuex中的getters和组件内computed很相似。那什么时候用vuex呢?

    • 如果数据还有其他组件复用
    • 需要跨多级组件传递数据
    • 持久化的数据(如登录后用户的信息)
    • 跟当前业务组件强相关的数据,可以放在组件内
  • 相关阅读:
    json2jsoncpp 高级应用篇
    重载delete(operator delete)
    发布一个 json转c++ 的一个转换小程序(依赖jsoncpp 0.60)
    json2jsoncpp 关键代码分析2
    json2jsoncpp 基础应用篇
    linux下编译android版本的ffmpeg库
    win7系统下无线网卡共享本地网卡给移动设备上网
    使用事件冒泡原理控制菜单或浮层
    多条件Sql语句
    测试 数据库是否链接成功
  • 原文地址:https://www.cnblogs.com/dobeco/p/11295126.html
Copyright © 2011-2022 走看看