vuex

在这里插入图片描述
vuex是vue配套的公共数据管理工具,它可以把一些共享的数据,保存到 vuex 中,方便 整个程序中的任何组件直接获取或修改我们的公共数据;

配置vuex的步骤

  1. 首先安装vuex,npm install vuex --save
  2. 导入包 import Vuex from 'vuex'
  3. 注册vuex到vue中 Vue.use(Vuex)
  4. new Vuex.Store() 实例,得到一个 数据仓储对象
var store = new Vuex.Store({
  state: {       
    count: 0
  },
  mutations: { 	
    increment(state) {
      state.count++
    },
    subtract(state, obj) { 	 
      console.log(obj)
      state.count -= (obj.c + obj.d)
    }
  },
  getters: {
    optCount: function (state) {
      return '当前最新的count值是:' + state.count
    }
  }
})
  1. 将 vuex 创建的 store 挂载到 VM 实例上, 只要挂载到了 vm 上,任何组件都能使用 store 来存取数据

总结:

  • 我们可以把 state 想象成 组件中的 data ,专门用来存储数据的。如果在 组件中,想要访问,store 中的数据,只能通过 this.$store.state.*** 来访问
  • 如果要操作 store 中的 state 值,只能通过 调用 mutations 提供的方法,才能操作对应的数据,不推荐直接操作 state 中的数据,因为 万一导致了数据的紊乱,不能快速定位到错误的原因,因为,每个组件都可能有操作数据的方法;
  • 如果组件想要调用 mutations 中的方法,只能使用 this.$store.commit('方法名'),这种 调用 mutations 方法的格式,和 this.$emit(‘父组件中方法名’)类似
  • mutations 的 函数参数列表中,最多支持两个参数,其中,参数1: 是 state 状态; 参数2: 通过 commit 提交过来的参数;
  • 如果 store 中 state 上的数据, 在对外提供的时候,需要做一层包装,那么 ,推荐使用 getters, 如果需要使用 getters ,则用 this.$store.getters.***
  • getters 中的方法:和组件中的过滤器比较类似,因为 过滤器和 getters 都没有修改原数据, 都是把原数据做了一层包装,提供给了 调用者;其次, getters 也和 computed 比较像, 只要 state 中的数据发生变化了,那么,如果 getters 正好也引用了这个数据,那么 就会立即触发 getters 的重新求值;
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值