介绍
Store的代码结构一般由State、Getters、Mutation、Actions这四种组成,也可以理解Store是一个容器,Store里面的状态与单纯的全局变量是不一样的,无法直接改变store中的状态。想要改变store中的状态,只有一个办法,显示地提交mutation。
import Vue from 'vue' import Vuex from 'vuex' Vue.use(Vuex) export default new Vuex.Store({ state: { }, getters:{ }, mutations: { }, actions: { } })
简单的Store
小朋友,要是没有安装vue-cli,不要看这个文档,看了也没用,咳咳···,创建一个vue项目直截了当,找到一个合适的文件夹,在此目录下打开终端,使用vue-cli命令行创建项目(项目名为murenziwei)
vue create murenziwei
你会被提示选取一个 preset。你可以选默认的包含了基本的 Babel + ESLint 设置的 preset,也可以选“手动选择特性”来选取需要的特性。
按下Enter,等da我现在只需要一个能运行的vue项目就行,命令执行完成后,文件夹会自动生成一个vue项目
按照上面图片红色框的命令来执行
/*切换目录*/
cd murenziwei /*启动项目*/ npm run serve
启动项目完毕后,打开浏览器,输入从终端得到的网址
到这,我们开始安装router、vuex。此时的项目结构如图以下
Ctrl+C退出启动,继续执行vue-cli,脚手架安装插件router和vuex开始
安装插件router
vue add router
输入一个大写Y,按下Enter
安装插件vuex
做法同上
vue add vuex
我们再重新看一下此时的项目结构,多了router.js和store.js,其它相关的文件也被修改
启动vue项目,npm run serve,在store.js中添加一个新状态count
import Vue from 'vue' import Vuex from 'vuex' Vue.use(Vuex) export default new Vuex.Store({ state: { count:1 }, mutations: { }, actions: { } })
修改组件HelloWorld,开始使用Store里注册的新状态
{{ this.$store.state.count }}
浏览效果
往store.js里的mustations添加改变状态值的加减功能,
import Vue from 'vue' import Vuex from 'vuex' Vue.use(Vuex) export default new Vuex.Store({ state: { count:1 }, mutations: { addmu(state){state.count++}, lessmu(state){state.count--} }, actions: { } })
回到HelloWorld组件, 添加增加和减少按钮,用来提交store的mutation
{{ this.$store.state.count }}
效果如下
由于mutation必须同步执行的限制,不方便实现复杂的功能。不过,别担心,看见了那个Actions吗?它就不受约束!我们可以在 它内部执行异步操作
修改store.js
import Vue from 'vue' import Vuex from 'vuex' Vue.use(Vuex) export default new Vuex.Store({ state: { count:1 }, mutations: { addmu(state){state.count++}, lessmu(state){state.count--} }, actions: { addac({commit}){commit('addmu')}, lessac({commit}){commit('lessmu')} } })
修改HelloWorld组件,将提交mutation改为分发Action,Actions支持载荷方式和对象方式
{{ this.$store.state.count }}
效果如下
为了更直观的感受下Store的魅力,在views文件夹中添加一个About.vue也使用store状态
About.vue
This is an about page
跳转About.vue或者Home.vue,store里面的状态值是怎么样的就是怎么样的?