vue的挖坑和爬坑之vuex的简单入门

首先vuex的中文文档https://vuex.vuejs.org/zh-cn/vue

首先vuex是什么,官方解释是

Vuex 是一个专为 Vue.js 应用程序开发的状态管理模式。它采用集中式存储管理应用的全部组件的状态,并以相应的规则保证状态以一种可预测的方式发生变化。Vuex 也集成到 Vue 的官方调试工具 devtools extension,提供了诸如零配置的 time-travel 调试、状态快照导入导出等高级调试功能。git

个人理解是

就是vue组件之间的数据管理github

event bus

对于vue组件之间的数据传递,父子之间的简单的传递还算是简单,而后你要在各个组件之间传递的话就不太方便了,有两种解决方案暂时我只接触到了两种,其中一种就是用event bus,在入口js中定义一个bus(巴士)vuex

new Vue({
  el: '#app',
  router,
  template: '<App/>',
  components: { App },
  data: {
    Bus: new Vue()
  }
});

 

而后你能够放数据放在bus中npm

 this.$root.Bus.$emit('tab',-1);

 

而后你也能够随时提取app

this.$root.Bus.$on('tab',(data)=>{
    console.log(data);
})

 

你能够理解为全局变量,可是因为设置变量的地方比较随意,而后用的多或者是数据量大的话不利于管理。函数

vuex

因而这时候vuex出来了。工具

先介绍一下vuex中几个关键点,这张图介绍了vuex的处理机制。this

 


state:既然vuex是用来储存数据的,那么咱们的储存地点就是这里。spa

mutations:对数据的处理都是在这里进行。

actions:专门用来提交mutations的。

getters:得到到state上的数据的。

因此总的来讲就是创建一个state,而后调用actions来提交mutations处理state中的数据,最后用getters获得state中的数据。

至于为何要用actions来提交mutations处理state中的数据,缘由是mutation 必须是同步函数,因此经过actions来调用mutations

首先npm install vuex一下,而后在src里新建一个store的文件夹,用来写vuex的文件,里面建立一个index.js,而后在main.js引入你建立的index.js并在new Vue中声明一下你引入的index文件。

import store from './store/index'

new Vue({
// 把 store 对象提供给 “store” 选项,这能够把 store 的实例注入全部的子组件 store, el:
'#app', router, template: '<App/>', components: { App } })

而后你能够在index里面写你的vuex文件了

 

import Vue from 'vue'
import Vuex from 'vuex'
Vue.use(Vuex);
//储存
const state = {
  i: 100
};
//处理state
const mutations = {
  ADD(state) {
    state.i++;
  }
};
//提交mutations
const actions = {
  add : function ({commit, state}) {
    commit(ADD)
  }
}
//得到state
const getters = {
  getdata : state => state.notes.i
}
// 挂载
export default new Vuex.Store({
  state,
  mutations,
  actions,
  getters
})

 

 

 

 而后你在组件中能够调用getters得到对应的值

this.$store.getters.getdata

而后你能够在组件中调用actions

this.$store.dispatch('add')

 以上是对vuex的最简单的一个demo的介绍

而后我的看到了几个比较好的简单的项目能够看看

https://github.com/ToWorkit/VUEX

https://github.com/coligo-io/notes-app-vuejs-vuex

还有的是若是你在actions和mutations中要传递值的话能够

//调用actions时传值
store.dispatch('add', {
  data: 10
})
//调用mutations时传值
store.commit('increment', {
   data: 10 
})

最后还有一个module讲一下,若是你的Vuex有两个模块要储存的话你能够经过这种方式储存

const moduleA = {
  state: { ... },
  mutations: { ... },
  actions: { ... },
  getters: { ... }
}

const moduleB = {
  state: { ... },
  mutations: { ... },
  actions: { ... }
}

const store = new Vuex.Store({
  modules: {
    a: moduleA,
    b: moduleB
  }
})

store.state.a // -> moduleA 的状态
store.state.b // -> moduleB 的状态
相关文章
相关标签/搜索