Vuex ~ 初识
现在我们store.js文件里增加一个常量对象
const state={
count:1
} 用export default 封装代码,让外部可以引用。
export default new Vuex.Store({
state
}) 新建一个vue的模板,xxx.vue。在模板中我们引入我们刚建的store.js文件,
并在模板中用{{$store.state.count}}输出count 的值。
<template>
<div>
<h2>{{msg}}</h2>
<hr/>
<h3>{{$store.state.count}}</h3>
</div>
</template>
<script>
import store from '@/vuex/store'
export default{
data(){
return{
msg:'Hello Vuex'
}
},
store //注意要先引用下
}
</script>
在store.js文件中加入两个改变state的方法。 const mutations={
//改变state的数值
add(state){
state.count++;
},
reduce(state){
state.count--;
}
}
export default new Vuex.Store({
state,
mutations
}) 在xxx.vue模板中加入两个按钮,并调用mutations中的方法
<div>
<button @click="$store.commit('add')">+</button>
<button @click="$store.commit('reduce')">-</button>
</div>
这样进行预览就可以实现对vuex中的count进行加减了
上面例子中 const state ,就是访问状态对象,也就是兄弟组件间的共享值。
下面是状态对象赋值给内部对象,也就是把stroe.js中的值,赋值给我们模板里data中的值 三种赋值方式:
一、通过computed的计算属性直接赋值
computed:{
count(){
return this.$store.state.count;
}
}
模板调用:{{count}} 缺点:当一个组件需要获取多个状态时候,将这些状态都声明为计算属性会有些重复和冗余。 二、通过mapState的《对象》来赋值
import {mapState} from 'vuex';
然后还在computed计算属性里写如下代码:
computed:mapState({
count:state=>state.count
}) 三、通过mapState的《数组》来赋值
computed:mapState(["count"])
3.Mutations修改state状态
1. mutations 相当于一个对象,对象里面放的是事件类型相对应的回调函数,作用就是进行状态更改;简单理解就相当于一个事件注册 2. $store.commit() //模板中调用mutations 里面的事件函数 传值:只需要在Mutations里再加上一个参数,并在commit的时候传递就就可以了
const mutations={
add(state,n){
state.count+=n;
},
reduce(state){
state.count--;
}
} 在XXX.vue里修改按钮的commit( )方法传递的参数,我们传递10,意思就是每次加10.
<p>
<button @click="$store.commit('add',10)">+</button>
<button @click="$store.commit('reduce')">-</button>
</p> 模板获取Mutations方法
实际开发中我们也不喜欢看到$store.commit( )这样的方法出现,我们希望跟调用模板里的方法一样调用。
例如:@click=”reduce” 就和没引用vuex插件一样。
要达到这种写法,只需要简单的两部就可以了: 在模板XXX.vue里用import 引入我们的mapMutations:
1.在模板XXX.vue里用import 引入我们的mapMutations:
import { mapState,mapMutations } from 'vuex'; 2.在模板的script标签里添加methods属性,并加入mapMutations
methods:mapMutations([
'add','reduce'
]), 3.通过上面两步后调用(注意额外参数直接写上)
<button @click="add(10)">+</button>
4.getters计算过滤操作
getters从表面是获得的意思,可以把他看作在《 获取数据之前 》进行的一种再编辑(注意模板显示getters操作后的值)
相当于对数据的一个过滤和加工,可以把它看作store.js的计算属性(类似于computed)
getter 的返回值会根据它的依赖被缓存起来,且只有当它的依赖值发生了改变才会被重新计算 《1》基本用法:
首先要在store.js里用const声明我们的getters属性。
const getters = {
count:function(state,getters){
return state.count +=getters.params_getter;
},
params_getter:function(){
return 1000
}
}
参数:
state :
getters : getters.xxx 来传递其他 getters 中的数据 写好了gettters之后,我们还需要在Vuex.Store()里引入
export default new Vuex.Store({
state,mutations,getters
}) 在store.js里的配置算是完成了,我们需要到模板页对computed进行配置
在vue 的构造器里边只能有一个computed属性,如果你写多个,只有最后一个computed属性可用,
所以要对computed属性进行一个改造。
改造时我们使用ES6中的展开运算符”…”。
computed:{
...mapState(["count"]), //相当于一个扩展
count(){
return this.$store.getters.count;
}
} 《2》用mapGetters简化模板写法:
都知道state和mutations都有map的引用方法把我们模板中的编码进行简化,我们的getters也是有的
首先用import引入我们的mapGetters
import { mapState,mapMutations,mapGetters } from 'vuex';
在computed属性中加入mapGetters
...mapGetters(["count"])
5.actions异步修改状态
actions和之前讲的Mutations功能基本一样
不同点是,
1.actions 提交的是 mutation,而不是直接变更状态。
2.actions是异步的改变state状态,而Mutations是同步改变状态。 在store.js中声明actions
actions是可以调用Mutations里的方法的,在actions里调用add和reduce两个方法
以下是事件注册的两种方式:
const actions ={
addAction(context){
context.commit('add',10)
},
reduceAction({commit}){
//由于context 与 store 实例具有相同方法和属性,所以可以提交mutation
commit('reduce')
}
} 在actions里写了两个方法addAction和reduceAction,在方法体里,我们都用commit调用了Mutations里边的方法。
context:上下文对象,这里你可以理解称store实例本身。
{commit}:直接把commit对象传递过来,可以让方法体逻辑和代码更清晰明了。 模板中的使用
<p>
<button @click="addAction">+</button>
<button @click="reduceAction">-</button>
</p>
改造一下我们的methods方法,首先还是用扩展运算符把mapMutations和mapActions加入
methods:{
...mapMutations([
'add','reduce'
]),
...mapActions(['addAction','reduceAction'])
} 用import把我们的mapActions引入才可以使用
import { mapState,mapMutations,mapGetters,mapActions } from 'vuex'; 增加异步检验
演示actions的异步功能,我们增加一个计时器(setTimeOut)延迟执行
setTimeOut(()=>{context.commit(reduce)},3000);
console.log('我比reduce提前执行');
6.module模块组(状态管理器的模块组操作)
随着项目的复杂性增加,我们共享的状态越来越多,这时候我们就需要把我们状态的各种操作进行一个分组,分组后再进行按组编写。
声明模块组:
在vuex/store.js中声明模块组,我们还是用我们的const常量的方法声明模块组。代码如下:
const moduleA = {
state: { ... },
mutations: { ... },
actions: { ... },
getters: { ... }
}
const moduleB = {
state: { ... },
mutations: { ... },
actions: { ... }
}
声明好后,我们需要修改原来 Vuex.Stroe里的值:
const store = new Vuex.Store({
modules: {
a: moduleA,
b: moduleB
}
}) store.state.a // -> moduleA 的状态
store.state.b // -> moduleB 的状态 在模板中使用:
现在我们要在模板中使用count状态,要用插值的形式写入
<h3>{{$store.state.a.count}}</h3>
如果想用简单的方法引入,还是要在我们的计算属性中rutrun我们的状态。写法如下:
computed:{
count(){
return this.$store.state.a.count;
}
}
Vuex ~ 初识的更多相关文章
- Vue爬坑之vuex初识
在 Vue.js 的项目中,如果项目结构简单, 父子组件之间的数据传递可以使用 props 或者 $emit 等方式 http://www.cnblogs.com/wisewrong/p/62660 ...
- Vuex初识
vuex是vue中单向数据流的一个状态管理模式,它可以集中存储管理应用中所有组件的状态,并且有一套相应的规则可以去预测数据的变化.类似与此的还有react中的redux,dva等状态管理模式. 一般我 ...
- 初识vuex
1.简介 vuex是 vue官方推荐的一个状态管理器.当我们遇到很多状态改变时,组件之间的通信就会变得复杂,这时候vuex的强大就展现出来. 我们从vuex的原理以及vuex的api两个部分介绍vue ...
- 初识vuex vuex 的基本用法
Vuex 是什么? 官方是这么说的:Vuex 是一个专为 Vue.js 应用程序开发的状态管理模式.它采用集中式存储管理应用的所有组件的状态,并以相应的规则保证状态以一种可预测的方式发生变化. 一个完 ...
- [20190620]日常学习记录(三)-初识promise及vuex
在学习promise之前重温了Ajax的原生js实现, 在原生js中发送一个http请求首先new XMLHttpRequest() 然后定义状态变更事件 浏览器监听请求的状态,触发不同状态下相应的代 ...
- 前端笔记之Vue(四)UI组件库&Vuex&虚拟服务器初识
一.日历组件 new Date()的月份是从0开始的. 下面表达式是:2018年6月1日 new Date(2018, 5, 1); 下面表达式是:2018年5月1日 new Date(2018, 4 ...
- vue(21)初识Vuex
Vuex是做什么的? 官方解释:Vuex 是一个专为 Vue.js 应用程序开发的状态管理模式. 它采用集中式存储管理应用的所有组件的状态,并以相应的规则保证状态以一种可预测的方式发生变化. Vuex ...
- Vuex原来可以这样上手
在Mvc模式大行其道的今天,后端通过各种Mvc框架实现视图与数据模型的隔离,而前端这方面也发展迅速.vue实现了Dom与viewModel双向绑定,使其视图的更新影响模型,模型的更新影响视图,你会不会 ...
- vue学习目录 vue初识 this指向问题 vue组件传值 过滤器 钩子函数 路由 全家桶 脚手架 vuecli element-ui axios bus
vue学习目录 vue学习目录 Vue学习一之vue初识 Vue学习二之vue结合项目简单使用.this指向问题 Vue学习三之vue组件 Vue学习四之过滤器.钩子函数.路由.全家桶等 Vue学习之 ...
随机推荐
- HDU 1715 大数java
大菲波数 Time Limit: 1000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others)Total Submis ...
- Codeforces Round #547 (Div. 3) 题解
Codeforces Round #547 (Div. 3) 题目链接:https://codeforces.com/contest/1141 A,B咕咕了... C. Polycarp Restor ...
- uboot主Makefile分析(t配置和编译过程详解)
1.编译uboot前需要三次make make distcleanmake x210_sd_configmake -j4 make distclean为清楚dist文件. make x210_sd_c ...
- Http字段含义
转载自:http://blog.csdn.net/sand_ant/article/details/10503579 一.request请求Header简介 Accept:--客户机支持的类型 Acc ...
- [LeetCode] 22. Generate Parentheses ☆☆
Given n pairs of parentheses, write a function to generate all combinations of well-formed parenthes ...
- 精通BIRT:Eclipse商务智能报表工具开发实践指南
http://blog.csdn.net/birtbird/article/details/8935520 [置顶] 精通BIRT:Eclipse商务智能报表工具开发实践指南 分类: BIRT 201 ...
- String.replaceAll()方法替换字符串中的反斜杠(\)
replaceAll()方法实际是采用正则表达式的规则去匹配的. 在regex中"\\"表示一个"\",在java中一个"\"也要用&quo ...
- 大聊Python----协程
协程 协程,又称微线程,纤程.英文名Coroutine.一句话说明什么是线程:协程是一种用户态的轻量级线程. 协程拥有自己的寄存器上下文和栈.协程调度切换时,将寄存器上下文和栈保存到其他地方,在切回来 ...
- epoll内核源码分析
转载:https://www.nowcoder.com/discuss/26226?type=0&order=0&pos=27&page=1 /* * fs/eventpo ...
- Laravel 调试器 Debugbar 和数据库导出利器 DbExporter 扩展安装及注意事项
一.Debugbar安装 参考:Laravel 调试利器 —— Laravel Debugbar 扩展包安装及使用教程 的“2.安装”部分 二.DbExporter安装 参考:Laravel 扩展推荐 ...