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 发行版的折腾主要是在虚拟机上完成.我的桌面电脑性能比较强大,玩玩虚拟机没啥问题,但是笔记本电脑就不行了.要在我的笔记本电脑上折腾多个 ...
随机推荐
- C#开发微信门户及应用(37)--微信公众号标签管理功能
微信公众号,仿照企业号的思路,增加了标签管理的功能,对关注的粉丝可以设置标签管理,实现更加方便的分组管理功能.开发者可以使用用户标签管理的相关接口,实现对公众号的标签进行创建.查询.修改.删除等操作, ...
- Day01 login module
知识点:模块导入 变量赋值的两种形式 格式化输出 for循环 if...else 嵌套 #!C:\Program Files\Python35/bin # -*- conding:utf-8 ...
- Java第三方数据库连接池库-DBCP-C3P0-Tomcat内置连接池
连接池原理 数据库连接池的基本思想就是为数据库连接建立一个“缓冲池”.预先在缓冲池中放入一定数量的连接,当需要建立数据库连接时,只需从“缓冲池”中取出一个,使用完毕之后再放回去.我们可以通过设定连接池 ...
- 在QMainWindow中利用多个QDockWidget构成标签页tab(原创)
功能描述: 在QMainWindow下,使用多个QDockWidget构成可切换,可拖动,可关闭的标签页:标签页的切换由相关联的QAction触发. 实现效果: 代码如下: QDockWidget * ...
- JavaScript图表FusionCharts免费在线公开课,由印度原厂技术工程师主讲,10月13日发车
FusionCharts公开课达人还你做 轻松晋升图表大师 [开课时间]10月13日 14:30[主讲老师]印度原厂技术工程师[开课形式]网络在线公开课[活动费用]前50名免费 现在就可以报名哦 报 ...
- Android中使用AsyncTask实现文件下载以及进度更新提示
Android提供了一个工具类:AsyncTask,它使创建需要与用户界面交互的长时间运行的任务变得更简单.相对Handler来说AsyncTask更轻量级一些,适用于简单的异步处理,不需要借助线程和 ...
- 使用WebRTC搭建前端视频聊天室——信令篇
博客原文地址 建议看这篇之前先看一下使用WebRTC搭建前端视频聊天室——入门篇 如果需要搭建实例的话可以参照SkyRTC-demo:github地址 其中使用了两个库:SkyRTC(github地址 ...
- 【代码笔记】iOS-由身份证号码返回性别
一,代码. - (void)viewDidLoad { [super viewDidLoad]; // Do any additional setup after loading the view. ...
- PHPmailer关于Extension missing: openssl报错的解决
最近在写一个网页的时候,需要用到PHPmailer来发送邮件,按照官网上给出的demo写出一个例子,却报错Extension missing: openssl 最后发现需要修改php.ini中的配置: ...
- ASP.NET MVC 3 网站优化总结(三)Specify Vary: Accept-Encoding header
继续进行 ASP.NET MVC 3 网站优化工作,使用 Google Page 检测发现提示 You should Specify Vary: Accept-Encoding header,The ...