zoukankan      html  css  js  c++  java
  • 简易的vuex用法

    vuex是vue中用于管理全局状态的一个组件,用于不同组件之间的通信,下面将介绍它的简单用法

    首先安装vue与vuex

    npm install vue
    npm install vuex --save

    然后创建一个单独的文件store.vue用来对vuex的处理和使用

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

    vuex有以下几种选项

    • state: Vuex store 实例的根 state 对象
    • mutations: 在 store 上注册 mutation,处理函数总是接受 state 作为第一个参数(如果定义在模块中,则为模块的局部状态),payload 作为第二个参数(可选)。
    • actions: 在 store 上注册 action。处理函数总是接受 context 作为第一个参数,payload 作为第二个参数(可选)。
    • getters: Vuex 允许我们在 store 中定义“getter”(可以认为是 store 的计算属性)。就像计算属性一样,getter 的返回值会根据它的依赖被缓存起来,且只有当它的依赖值发生了改变才会被重新计算。
    • modules: 包含了子模块的对象,会被合并到 store。
    • plugins: 一个数组,包含应用在 store 上的插件方法。
    • strict: 使 Vuex store 进入严格模式,在严格模式下,任何 mutation 处理函数以外修改 Vuex state 都会抛出错误。
     
    我们今天只用到state,mutations,actions,getters
    const state = {
        token: '' // 定义state的初始值,组建中我们可以用$store.state.token来调用
    }
    const mutations = {
      setToken (state, token) {
        state.token = token || ''
      }
    }

    我们可以用$store.commit('setToken', 'xxxxxx')来改变state中token的值

    const actions = {
      setToken (context) {//这里的context和我们使用的$store拥有相同的对象和方法
        context.commit('setToken');
        //你还可以在这里触发其他的mutations方法
      },
    }

    可以使用 $store.dispatch('setToken') 来触发 action 中的 setToken方法。actions里面可以执行异步操作。

    getters: {
        doneTodos: (state, getters) => {
          return state.todos.filter(todo => todo.done)
        }
      }

    getters类似于vue的计算属性,它的作用是用来派生一些新的状态,比如我们要把state状态的数据进行一次映射后者筛选,并把这个状态返回给组件使用。

    最后将生成的实例导进main.js

    export default new Vuex.Store({
      state,
      mutations,
      actions,
    getters })

    main.js

    import store from './store'
    new Vue({
      el: '#app',
      store,
      components: { App },
      template: '<App/>'
    })

    这样vuex的功能已经可以用了,如果业务需要,可以慢慢将它们的选项都完善进去

  • 相关阅读:
    洛谷 P4071 [SDOI2016]排列计数
    问题 G: 【一本通提高同余问题】计算器
    问题 A: 【一本通提高组合数学】Bullcow 牡牛和牝牛
    浅谈卢卡斯定理(非扩展)
    2019西安联训B层 Day 6练习题 问题 C: 扩展欧几里得
    react使用lazy()和Suspense实现根据路由进行代码分割
    react-loadable 使用高阶组件动态import组件,实现代码分割(code-splitting)
    react angular vue流行度对比
    react 服务端渲染(ssr) 框架 Next.js
    超级字符串内class正则匹配替换 可以用于css modules
  • 原文地址:https://www.cnblogs.com/kdcg/p/9099636.html
Copyright © 2011-2022 走看看