vuex+Es6语法补充-Promise
Vuex 是一个专为 Vue.js 应用程序开发的状态管理模式,采用 集中式存储管理
单页面的状态管理/多页面状态管理
使用步骤:
// 1.导入
import Vuex from 'vuex'
// 2.安装插件
Vue.use(Vuex)
// 3.创建对象
const store = new Vuex.Store({
state, // 状态
mutations, // 同步信息变化
actions, // 异步信息变化
getters, // 变化属性 相当于computed属性
modules: { // 模型
a:moduleA
}
})
// 4.导出
export default store
1.mutations状态更新
Mutation主要包括两部分:
字符串的事件类型(type)
一个回调函数(handler),该回调函数的第一个参数就是state。
// 定义方式:
decrement(state){
state.counter--
}
// 通过mutations更新
subtraction(){
this.$store.commit('decrement')
}
// 传递参数:
decrementCount(state,payload){
// 普通提交
// state.counter+=count
// 特殊提交
state.counter += payload.count
},
// 通过mutations更新
addCount(count){
// 普通提交
// this.$store.commit('decrementCount',count)
// 特殊提交
this.$store.commit({
type: 'decrementCount',
count // ccount的参数在下面button中面传递
})
}
<button @click="addCount(5)">+5</button>
mutations响应规则:
当给state中的对象添加新属性时, 使用下面的方式:
方式一: 使用Vue.set(obj, 'newProp', 123)
方式二: 用新的对象给旧对象重新赋值
2.getters使用
powerCounter(state){
return state.counter*state.counter
},
more20stu(state){
return state.students.filter(s=>s.age > 20)
},
more20stuLength(state,getters){
return getters.more20stu.length
},
moreAgestu(state){
// return function(age){
// return state.students.filter(s=>s.age>age)
// }
return age=>{
return state.students.filter(s=>s.age>age)
}
}
3.actions使用
context是和store对象具有相同方法和属性的对象
我们可以通过context去进行commit相关的操作, 也可以获取context.state等
context是上下文 相当于store
updateInfo(state){
state.info.name='zranguai'
}
clic(){
// this.$store.commit('updateInfo')
// this.$store.dispatch('aUpdateInfo',{
// message:'我是message',
// success: ()=>{
// console.log('打印成功');
// }
// })
this.$store.
dispatch('aUpdateInfo','我是携带信息')
.then(res=>{
console.log('里面完成了提交');
console.log(res);
})
},
}
<button @click='clic'>哈哈哈</button>
Es6语法补充-Promise
Promise是异步编程的一种解决方案
// 1.定时器的异步事件
new Promise((resolve,reject)=>{
setTimeout(()=>{
// 1.成功调用resolve
resolve('hello')
// 2.失败调用reject
reject('error')
},1000)
}).then((data)=>{
console.log(data);
}).catch(err=>{
console.log(err);
})
2.Promise三种状态
pending:等待状态,比如正在进行网络请求,或者定时器没有到时间。
fulfill:满足状态,当我们主动回调了resolve时,就处于该状态,并且会回调.then()
reject:拒绝状态,当我们主动回调了reject时,就处于该状态,并且会回调.catch()
3.链式调用简写
1.return Promise.resovle(data)
2.return data
3.promise的all方法使用
Promise.all([
new Promise((resolve,reject)=>{
setTimeout(()=>{
resolve({
name:'why',
age:18
})
},2000)
}),
new Promise((resolve,reject)=>{
setTimeout(()=>{
resolve('result2')
},2000)
})
]).then(results=>{
console.log(results);
})
vuex+Es6语法补充-Promise的更多相关文章
- es6语法中promise的使用方法
Promise是一个构造函数,它有resolve,reject,race等静态方法;它的原型(prototype)上有then,catch方法,因此只要作为Promise的实例,都可以共享并调用Pro ...
- es6 语法 (Promise)
{ // 基本定义 let ajax = function(callback) { console.log('执行'); //先输出 1 执行 setTimeout(function() { call ...
- ES6语法 promise用法
ES6语法 promise用法 function doSomething(){ return new Promise((resolve,reject)=>{ resolve('jjjj');// ...
- ES6新增语法(五)——Promise详解
Promise介绍 promise是一个对象,从它可以获取异步操作的消息.有all.race.reject.resolve这几个方法,原型上有then.catch等方法. Promise的两个特点: ...
- ES6语法知识
let/const(常用) let,const用于声明变量,用来替代老语法的var关键字,与var不同的是,let/const会创建一个块级作用域(通俗讲就是一个花括号内是一个新的作用域) 这里外部的 ...
- webpack中使用babel处理es6语法
index.js const arr = [ new Promise(()=>{}), new Promise(()=>{}) ]; arr.map(item => { consol ...
- 把JavaScript代码改成ES6语法不完全指南
目录 * 核心例子 * 修改成静态变量(const)或块级变量(let) * 开始修改 * 疑问解释(重复定义会发生什么) * 疑问解释(let的块级作用域是怎样的) * 疑问解释(const定义的变 ...
- Webstorm添加新建.vue文件功能并支持高亮vue语法和es6语法
转载:https://blog.csdn.net/qq_33008701/article/details/56486893 Webstorm 添加新建.vue文件功能并支持高亮vue语法和es6语法 ...
- 在Node中使用ES6语法
Node本身已经支持部分ES6语法,但是import export,以及async await(Node 8 已经支持)等一些语法,我们还是无法使用.为了能使用这些新特性,我们就需要使用babel把E ...
随机推荐
- 解决使用 swiper 常见的问题
使用 swiper 的过程中个人总结 1. swiper插件使用方法, 直接查看文档 swiper基础演示 swiper API文档 2.swiper近视初始化时, 其父级元素处于隐藏状态(displ ...
- jq移动端图片预览 (fly-zomm-img.js)
效果图: ===>==> 里面还与很多属性设置: index 关闭按钮等等 代码: //html-----------------------<div class="he ...
- 数组 indexOf()
众所周知,indexOf()这个方法经常出现在字符串的使用中,也许是用来寻找字符串中某一字符在字符串中的位置,或者也可以用来寻找字符串中重复出现的字符有哪些.对于刚接触 JS 的我们来说,在对数组的操 ...
- Centos搭建 LAMP 服务器教程
搭建 LAMP 服务 搭建 MySQL 数据库 安装 MySQL 使用 yum 安装 MySQL: yum install mysql-server -y 安装完成后,启动 MySQL 服务: ser ...
- 调试了一个早上, 定位了一个chrome的新问题, 新版chrome 不能有效的追踪客户来源Referer了
- 什么是3D建模?
一.3D建模是什么 将所见所想用立体三维的方式通过计算机技术表现出来,这就是3D建模,比如你看到了一个可爱呆萌的卡通人物又或是华丽酷炫的变形金刚,总之就是你认为美好的立体实物 你想将它用计算机技术完美 ...
- python输出二维数组中,每行N个最大值的索引
`import heapq import numpy as np import random a = np.random.randint(50,size= (4,5)) a = np.array(a) ...
- Struts2-day1总结
1.Struts2的基本执行流程(详见我的博客) 2.Struts2的分模块开发 如果有多个项目的Struts.xml写在一起,容易造成数据混乱,所以可以使用分模块的方法,在项目下新建*.xml配置文 ...
- victoriaMetrics之byteBuffer
victoriaMetrics之byteBuffer VictoriaMetrics经常会处理数目庞大的指标,在处理的过程中会涉及指标的拷贝,如果在指标拷贝时都进行内存申请的话,其内存消耗和性能损耗都 ...
- 在容器使用stress指令进行负载压测
安装stressstress是一个linux下的压力测试工具,专门为那些想要测试自己的系统,完全高负荷和监督这些设备运行的用户 在容器中安装docker容器压测工具 stress #先安装一些基础工具 ...