vuex

157 阅读2分钟

vuex 是 Vue 配套的 公共数据管理工具,它可以把一些共享的数据,保存到 vuex 中,方便 整个程序中的任何组件直接获取或修改我们的公共数据。 Vuex解决了组件之间同一状态的共享问题。 vuex的使用: 1、src目录下面新建一个vuex的文件夹 2、vuex 文件夹里面新建一个store.js 3、安装vuex,cnpm install vuex --save 4、在刚才创建的store.js引入vue 引入vuex 并且use vuex import Vue from 'vue' import Vuex from 'vuex' Vue.use(Vuex) 5、定义数据state,定义方法mutations,暴露出去

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

const store = new Vuex.Store({
  state: {
    count: 1
  },
  mutations: {
    add (state) {
      ++state.count
    }
  }
});
export default store;

6.1组建里面使用vuex: 1.引入 store import store from '../vuex/store.js'; 2、注册 将store,放在data,methods同级下 3、获取state里面的数据
this.store.state.count
4、触发 mutations 改变 state里面的数据
      组件里写一个方法,调用store里面的方法
      this.store.commit('add');

6.2全局使用store import store from "./vuex/store" 将 vuex 创建的store挂载到VM实例上store:store,也可以使用对象简写。

第二遍学习笔记 上面的方法是把store单独提取出来了,下面是吧放到main文件里使用

  1. 运行 cnpm i vuex -S
  2. 导入包 import Vuex from 'vuex'
  3. 注册vuex到vue中 Vue.use(Vuex)
  4. new Vuex.Store() 实例,得到一个 数据仓储对象
  5. 将 vuex 创建的 store 挂载到 VM 实例上, 只要挂载到了 vm 上,任何组件都能使用 store 来存取数据
const store = new Vuex.Store({
  state: {
    count: 0
    // 大家可以把 state 想象成 组件中的 data ,专门用来存储数据的
    // 如果在 组件中,想要访问,store 中的数据,只能通过 this.$store.state.*** 来访问
  },
  mutations: {
    // 注意: 如果要操作 store 中的 state 值,只能通过 调用 mutations 提供的方法,才能操作对应的数据,不推荐直接操作 state 中的数据,因为 万一导致了数据的紊乱,不能快速定位到错误的原因,因为,每个组件都可能有操作数据的方法;
    increment(state) {
      state.count++
    },
    // 注意: 如果组件想要调用 mutations 中的方法,只能使用 this.$store.commit('方法名')
    // 这种 调用 mutations 方法的格式,和 this.$emit('父组件中方法名')
    subtract(state, obj) {
      // 注意: mutations 的 函数参数列表中,最多支持两个参数,其中,参数1: 是 state 状态; 参数2: 通过 commit 提交过来的参数;
      console.log(obj)
      state.count -= (obj.c + obj.d)
    }
  },
  getters: {
    // 注意:这里的 getters, 只负责 对外提供数据,不负责 修改数据,如果想要修改 state 中的数据,请 去找 mutations
    optCount: function (state) {
      return '当前最新的count值是:' + state.count
    }
    // 经过咱们回顾对比,发现 getters 中的方法, 和组件中的过滤器比较类似,因为 过滤器和 getters 都没有修改原数据, 都是把原数据做了一层包装,提供给了 调用者;
    // 其次, getters 也和 computed 比较像, 只要 state 中的数据发生变化了,那么,如果 getters 正好也引用了这个数据,那么 就会立即触发 getters 的重新求值;
  }
})