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的更多相关文章

  1. es6语法中promise的使用方法

    Promise是一个构造函数,它有resolve,reject,race等静态方法;它的原型(prototype)上有then,catch方法,因此只要作为Promise的实例,都可以共享并调用Pro ...

  2. es6 语法 (Promise)

    { // 基本定义 let ajax = function(callback) { console.log('执行'); //先输出 1 执行 setTimeout(function() { call ...

  3. ES6语法 promise用法

    ES6语法 promise用法 function doSomething(){ return new Promise((resolve,reject)=>{ resolve('jjjj');// ...

  4. ES6新增语法(五)——Promise详解

    Promise介绍 promise是一个对象,从它可以获取异步操作的消息.有all.race.reject.resolve这几个方法,原型上有then.catch等方法. Promise的两个特点: ...

  5. ES6语法知识

    let/const(常用) let,const用于声明变量,用来替代老语法的var关键字,与var不同的是,let/const会创建一个块级作用域(通俗讲就是一个花括号内是一个新的作用域) 这里外部的 ...

  6. webpack中使用babel处理es6语法

    index.js const arr = [ new Promise(()=>{}), new Promise(()=>{}) ]; arr.map(item => { consol ...

  7. 把JavaScript代码改成ES6语法不完全指南

    目录 * 核心例子 * 修改成静态变量(const)或块级变量(let) * 开始修改 * 疑问解释(重复定义会发生什么) * 疑问解释(let的块级作用域是怎样的) * 疑问解释(const定义的变 ...

  8. Webstorm添加新建.vue文件功能并支持高亮vue语法和es6语法

    转载:https://blog.csdn.net/qq_33008701/article/details/56486893 Webstorm 添加新建.vue文件功能并支持高亮vue语法和es6语法 ...

  9. 在Node中使用ES6语法

    Node本身已经支持部分ES6语法,但是import export,以及async await(Node 8 已经支持)等一些语法,我们还是无法使用.为了能使用这些新特性,我们就需要使用babel把E ...

随机推荐

  1. JavaScript の 内容属性(HTML属性attribute)和 DOM 属性(property)

    [博文]内容属性(HTML属性)和 DOM 属性 标签: 博文 JavaScript 粗略解读(与jQuery做对比) 内容属性(HTML属性) : attribute DOM 属性(Element属 ...

  2. 【每日日报】第三十二天---DataOutputStream写文件

    1 今天继续看书 DataOutputStream写文件 1 package File; 2 import java.io.IOException; 3 import java.io.FileOutp ...

  3. SQL语句总结---数据库操作

    https://blog.csdn.net/hallomrzhang/article/details/85010014 数据库操作 查看所有数据库 show databases; 1 查看当前使用的数 ...

  4. 搭建 LNMP 环境

    搭建 LNMP 环境 搭建 Nginx 静态服务器 安装 Nginx 使用 yum 安装 Nginx: yum install nginx -y 修改 /etc/nginx/conf.d/defaul ...

  5. 居中select中的option选项

    select经常有长短不一的选项:选择不同的选项居中不会生效: 使用text-align:center;text-align-last: center;  可以让所有选项都居中: 关于text-dec ...

  6. linux权限与系统信息

    权限 1.权限分为3个部分 可读(r) 可写(w) 可执行(x) 没有对应权限(-) 2.权限位 权限位主要分为三个部分,分别是属主.属组以及其他人 rwx : 属主 r-x : 属组 r-x : 其 ...

  7. eclipse-java-2018-09-win32-x86_64配置tomcat(内含更新eclipse,如何解决添加时找不到最新tomcat版本)

    我下的是eclipse精简版,建议下载企业版,可以省略后面的很多步骤(其中的辛酸...) 这里就是说明下载精简版的eclipse如何配置tomcat的步骤,其实还是更新eclipse的步骤 1.首先点 ...

  8. DOM的事件传播机制

    在dom传播的过程中,一个事件有触发到响应,经历了三个过程: 1,目标的挖洞过程,先有html标签触发事件,然后向子标签一层一层传播,但未执行,,直到找到事件目标为止,这个过程叫做挖洞过程, 2,目标 ...

  9. 1903021116-吉琛- JAVA第二周作业—Java程序编写

    项目 内容 课程班级博客链接 19级信计班 这个作业要求链接 https://www.cnblogs.com/thelovelybugfly/p/9641367.html 我的课程学习目标 1. 学习 ...

  10. canvas基础简单易懂教程(完结,多图)

    目录 Canvas学习 一. Canvas概述 1.1 Hello world 1.2 Canvas的像素化 1.3 Canvas的动画思想 1.4 面向对象思维实现canvas动画 二.Canvas ...