vuex 初体验
vuex是vue的状态管理工具,vue进阶从es6和npm开始,es6推荐阮一峰大神的教程。
vuex学习从官方文档和一个记忆小游戏开始。本着兴趣为先的原则,我先去试玩了一把-->。
Vuex 是一个专为 Vue.js 应用程序开发的状态管理模式,如果你刚接触这个东东肯定像我一样蒙,所以我选择把这个游戏的源码从头到尾看一遍,主要看文件夹vuex里的actions,mutations,store部分,理解了一行就加一个批注。直到全部理解了为止。
从图说起:
这个图最简单的表示了vuex的工作流程。以memory小游戏为例,它的主要组件是chessboard组件,下面是一堆card组件,在小游戏的stage对象里面有一个leftmatched对象,用于表示还有多少对扑克牌没有匹配成功。
vuex store实例
每一个 Vuex 应用的核心就是 store(仓库),这里存放了应用中的大部分状态stage,操作状态的mutations,触发mutations的actions。
以上面的那个小游戏为例,最基本的有三个状态stage,ready,playing,pass,分别表示开始玩之前,正在玩和通关三种状态,这些状态都被放在stage中。
在mutations中有一个reset方法,用于重置通关后再来一局。将cards全部翻转过去,也就是重置了状态。
可以用类比来理解store实例:
Vue | Vuex |
Vue实例vm | Vuex.Store 实例store |
vm的data属性 | store实例的stage属性 |
vm的methods方法 | store实例的mutations方法 |
vm的computed属性 | store实例的getter属性 |
上面的每一条在作用上基本上可以看作是一一对应的,stage对应data,getters对应computed属性等。
store实例的生成
看来自教程的代码,与生成vue实例一样,同样是调用一个构造函数Vuex.Store,并传入一个option对象,从而生成一个store实例。这个实例包含了应用的状态,和改变应用状态的方法。
const store = new Vuex.Store({
state: {
count: 0
},
mutations: {
increment (state) {
state.count++
}
}
})
但是store实例尽管提供了改变状态的方法,它本身是不改变状态的。改变状态的源头来自组件和生命周期的钩子函数。 在组件中,使用计算属性来读取应用的状态,通过action——>mutation——>stage来改变应用的stage。
另外,并不是说应用的所有状态都应该放到vuex的stage中,stage主要放用于共享的,或者应用级别的状态,memory小游戏为例,一张卡片是否翻转应该属于card组件的状态,应当局部存放,而玩家匹配了几组卡片则属于应用层面的状态,应当放在vuex中。
vuex的注入
vuex的store实例是作为生成vue实例的选项之一被注入到vue实例中的,同时可以被实例中的各组件所访问。看下面的例子main.js用于生成vue实例,store.js用于生成store实例:
//main.js
import store from './vuex/store'//引入store实例 new Vue({
el: '#app',
template: '<App/>',
components: { App },
store //store作为生成vue实例的选项之一,与el,template等一起被引入
}) //store.js export store实例,在上面被引入
import Vuex from 'vuex'
Vue.use(Vuex);
/..../
export default new Vuex.Store({//store实例接口,没有写actions
state,
getters,
mutations
})
vuex和组件
vuex是一个就像一个状态仓库,组件想要访问这些共享的状态,或者触发改变状态的mutations方法,可以这样做:
this.$store.stage.onlyUnfinish//访问共享的状态
this.$store.commit(listByImportant)//出发vuex mutations中的排序方法
vuex 初体验的更多相关文章
- Nuxt+Vuex初体验
小呀嘛小二郎,背着书包上学堂... 今天一个困扰了我一周时间的问题终于被我解决了,值得庆祝 在Nuxt中使用Vuex实现数据存储 首先: 在store目录下新建一个index.js文件 需要有两个组件 ...
- Vue+Vuex初体验
首先: 安装vuex npm install vuex -S 需要有两个组件(HelloWord.vue 和 HelloDemo.vue)[组件自定义] 注册路由 注册store 测试 一.需要有两个 ...
- .NET平台开源项目速览(15)文档数据库RavenDB-介绍与初体验
不知不觉,“.NET平台开源项目速览“系列文章已经15篇了,每一篇都非常受欢迎,可能技术水平不高,但足够入门了.虽然工作很忙,但还是会抽空把自己知道的,已经平时遇到的好的开源项目分享出来.今天就给大家 ...
- Xamarin+Prism开发详解四:简单Mac OS 虚拟机安装方法与Visual Studio for Mac 初体验
Mac OS 虚拟机安装方法 最近把自己的电脑升级了一下SSD固态硬盘,总算是有容量安装Mac 虚拟机了!经过心碎的安装探索,尝试了国内外的各种安装方法,最后在youtube上找到了一个好方法. 简单 ...
- Spring之初体验
Spring之初体验 Spring是一个轻量级的Java Web开发框架,以IoC(Inverse of Control 控制反转)和 ...
- Xamarin.iOS开发初体验
aaarticlea/png;base64,iVBORw0KGgoAAAANSUhEUgAAAKwAAAA+CAIAAAA5/WfHAAAJrklEQVR4nO2c/VdTRxrH+wfdU84pW0
- 【腾讯Bugly干货分享】基于 Webpack & Vue & Vue-Router 的 SPA 初体验
本文来自于腾讯bugly开发者社区,非经作者同意,请勿转载,原文地址:http://dev.qq.com/topic/57d13a57132ff21c38110186 导语 最近这几年的前端圈子,由于 ...
- 【Knockout.js 学习体验之旅】(1)ko初体验
前言 什么,你现在还在看knockout.js?这货都已经落后主流一千年了!赶紧去学Angular.React啊,再不赶紧的话,他们也要变out了哦.身旁的90后小伙伴,嘴里还塞着山东的狗不理大蒜包, ...
- 在同一个硬盘上安装多个 Linux 发行版及 Fedora 21 、Fedora 22 初体验
在同一个硬盘上安装多个 Linux 发行版 以前对多个 Linux 发行版的折腾主要是在虚拟机上完成.我的桌面电脑性能比较强大,玩玩虚拟机没啥问题,但是笔记本电脑就不行了.要在我的笔记本电脑上折腾多个 ...
随机推荐
- JavaWeb_day08_EL JSTL
本文为博主辛苦总结,希望自己以后返回来看的时候理解更深刻,也希望可以起到帮助初学者的作用. 转载请注明 出自 : luogg的博客园 谢谢配合! day08 EL JSTL EL表达式 语法:${} ...
- Css3新特性总结之边框与背景(二)
一.条纹背景 利用background为linear-gradient函数实现,linear-gradient取值如下: <angle>:角度,渐变的方向 to left right to ...
- react native初步常见问题
首先按照资料一步步搭建环境运行,然后成功了,很激动,可是,安卓就是没这么容易成功,还是太年轻了 could not get batchedbridge, make sure your bundle i ...
- iOS获取网络图片大小
在iOS开发过程中经常需要通过网络请求加载图片,有时,需要在创建UIImageView或UIButton来显示图片之前需要提前知道图片的尺寸,根据图片尺寸创建对应大小的控件.但是对于网络图片来说,要想 ...
- Laravel大型项目系列教程(五)之文章和标签管理
一.前言 本节教程将大概完成文章和标签管理以及标签关联. 二.Let's go 1.文章管理 首先创建管理后台文章列表视图: $ php artisan generate:view admin.art ...
- css权威指南--笔记
第1章 css和文档 1,元素:替换元素(img input),非替换元素(大多数span). 2,link:rel(代表关系:stylesheet,候选样式表:alternate styleshee ...
- Hadoop分布式系统的安装部署
1.关于虚拟机的复制 新建一台虚拟机,系统为CentOS7,再克隆两台,组成一个三台机器的小集群.正常情况下一般需要五台机器(一个Name节点,一个SecondName节点,三个Data节点.) 此外 ...
- [转]用Middleware给ASP.NET Core Web API添加自己的授权验证
本文转自:http://www.cnblogs.com/catcher1994/p/6021046.html Web API,是一个能让前后端分离.解放前后端生产力的好东西.不过大部分公司应该都没能做 ...
- 开发管理系统时,安装sqlserver2005问题整理
最近在为单位开发一个综合管理系统.但是由于时间的问题,有时候就把程序带回家进行修改.但是家里有没有环境,就把数据库文件和程序带回家,可是随之问题来了.要重新在家里陪着开发环境,vs2008非常快的就安 ...
- 优化IPOL网站中基于DCT(离散余弦变换)的图像去噪算法(附源代码)。
在您阅读本文前,先需要告诉你的是:即使是本文优化过的算法,DCT去噪的计算量依旧很大,请不要向这个算法提出实时运行的苛刻要求. 言归正传,在IPOL网站中有一篇基于DCT的图像去噪文章,具体的链接地址 ...