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学习之 ...
随机推荐
- JavaScript数据类型转换方法汇总
转换为布尔型 用两次非运算(!): 1 !!5 ==> true 用布尔型的构造函数: 1 new Boolean(5) == > true 值转换为布尔类型为false:0,+0,-0, ...
- 单例 ------ JAVA实现
单例:只能实例化一个对象,使用场景比如打印机. 最推荐的是采用饿汉式:双重校验锁用到了大量的语法,不能保证这些语法在所用场合一定没问题,所以不是很推荐:总之简单的才是最好的,就饿汉式!!! C++ 创 ...
- [Android问答] px、dp和sp,这些单位有什么区别?
相信每个Android新手都会遇到这个问题,希望这篇帖子能让你不再纠结. px: 即像素,1px代表屏幕上一个物理的像素点: px单位不被建议使用,因为同样100px的图片,在不同手机上显示的实际大小 ...
- You can't specify target table 'table' for update in FROM clause
delete from table1 where ID not in(select max(ID) ID from table1 group by row1) and row1 ) # 出现错误 # ...
- Codeforces Round #380 (Div. 2)/729B Spotlights 水题
Theater stage is a rectangular field of size n × m. The director gave you the stage's plan which act ...
- Spring Boot 配置定时任务
package com.zooper.demo; import java.text.SimpleDateFormat; import java.util.Date; import org.slf4j. ...
- c# socket select 模型代码(u3d)
其实写过多次网络链接.但是因为换了工作,又没电脑在身边,所以以前的代码都没办法翻出来用. 所以从今天起,一些常用的代码只好放到网上. 公司有一个局域网的游戏.本来想用u3d的rpc就可以完成.但是后来 ...
- 求逆元的两种方法+求逆元的O(n)递推算法
到国庆假期都是复习阶段..所以把一些东西整理重温一下. gcd(a,p)=1,ax≡1(%p),则x为a的逆元.注意前提:gcd(a,p)=1; 方法一:拓展欧几里得 gcd(a,p)=1,ax≡1( ...
- windows phone 8.1如何访问应用商店,商店评论的连接
Windows Phone 8.1 中可以使用这个链接跳转到应用评论页面: await Windows.System.Launcher.LaunchUriAsync( new Uri("ms ...
- POJ 3069 Saruman's Army (模拟)
题目连接 Description Saruman the White must lead his army along a straight path from Isengard to Helm's ...