Vuex mutitons和actions初使用详解


Posted in Javascript onMarch 04, 2019

Mutations

mutations 必须是同步函数,为什么?

举个例子:  官方案例

mutations: {
 someMutation (state) {
  api.callAsyncMethod(() => {
   state.count++
  })
 }
}

我们都知道任何回调函数中进行的状态改变都是无法追踪的,  devtools会对mutations的每一条提交做记录,记录上一次提交之前和提交之后的状态,在上面的例子中无法实现捕捉状态,因为在执行mutations时,内部回调函数还没有执行,

所以此时无法捕捉状态.

再简单来讲,就像大家都吃过核桃,核桃刚产下来的时候是带一层绿色的皮的,我们需要将绿色烧掉,弄掉了,才是我们在市场上见到的只有外面硬壳的核桃,如果我们只剥去绿皮,是不能直接吃的,因为还有一层壳胡着呢.

Actions

vuex肯定不甘示弱,为了解决mutations只有同步的问题,提出了actions(异步),专门用来解决mutations只有同步无异步的问题.

1. 首先先了解一下actions

(1).MUTATIONS

const state = {

xxx: null

},

const mutations = {


[setState](state, value) {



state.xxx = value


}

}

此处value可以是对象,可以是值等

组件调用方式: this.$store.commit('setState', [value])

(2).ACTIONS

// 第一种写法简写形式

const actions = {


[addPlus]({commit}) { // 简写方式,待研究



commit('[setState]', value)



//此处value可以是对象,可以是固定值等


}

}

// 第二种形式

const actions = {


[addPlus](context) {



//context 官方给出的指定对象, 此处context可以理解为store对象



context.commit('[setState]', value)


}

}

/* 两处的commit都是提交的mutations中的字符串的事件类型名称,对应会调用mutations中的回调函数 */

actions在组件中的调用方式: 

import mapActions from 'vuex'

methods: {


...mapActions: ([


 'addPlus' 


]),


setAddPlus () {



this.$store.dispatch('addPlus', [value]) // 异步调用mutations


}

}

Vuex 状态管理

Vuex 依赖于 Vue 用来管理 Vue 项目状态

状态的修改依赖于 commit 和 dispatch

import Vue from 'Vue';
import Vuex from 'Vuex';

export default new Vuex.Store({
  state:{
    count:100
  },
  mutations:{
    change(state,payload){
      state.count += payload;
    }
  },
  actions:{
    change(context,palyload){
      context.commit('change',palyload);// 异步触发 mutaiton
    }
  },
  getters:{
    getCount(){
      return state.count;
    }
  }
})
{{$store.state.count}}
<button @click="commitChange">更改count</button>
<button @click="dispatchChange">更改count</button>

...

methods:{
  commitChange(){
    this.$store.commit('change',1);
  },
  dispatchChange(){
    this.$sotre.dispatch('change',10);
  }
}

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
JS JavaScript获取Url参数,src属性参数
Mar 09 Javascript
JavaScript两种跨域技术全面介绍
Apr 16 Javascript
JavaScript禁止复制与粘贴的实现代码
May 16 Javascript
jQGrid动态填充select下拉框的选项值(动态填充)
Nov 28 Javascript
Bootstrap栅格系统的使用和理解2
Dec 14 Javascript
canvas实现绘制吃豆鱼效果
Jan 12 Javascript
laravel5.4+vue+element简单搭建的示例代码
Aug 29 Javascript
vue2.0 和 animate.css的结合使用
Dec 12 Javascript
layui获取多选框中的值方法
Aug 15 Javascript
javascript动态创建对象的属性详解
Nov 07 Javascript
vue 添加和编辑用同一个表单,el-form表单提交后清空表单数据操作
Aug 03 Javascript
Vue axios获取token临时令牌封装案例
Sep 11 Javascript
JS重学系列之聊聊new操作符
Mar 04 #Javascript
jQuery实现的导航条点击后高亮显示功能示例
Mar 04 #jQuery
ES10 特性的完整指南小结
Mar 04 #Javascript
node.js使用express框架进行文件上传详解
Mar 03 #Javascript
微信小程序新手教程之启动页的重要性
Mar 03 #Javascript
微信小程序新手教程之页面打开数量限制
Mar 03 #Javascript
JS实现的冒泡排序,快速排序,插入排序算法示例
Mar 02 #Javascript
You might like
超外差式晶体管收音机的组装与统调
2021/03/01 无线电
ThinkPHP的模版中调用session数据的方法
2014/07/01 PHP
表单(FORM)的一些实用效果代码
2007/03/25 Javascript
extjs form textfield的隐藏方法
2008/12/29 Javascript
JavaScript中URL编码函数代码
2011/01/11 Javascript
jquery 读取页面load get post ajax 四种方式代码写法
2011/04/02 Javascript
jquery学习笔记 用jquery实现无刷新登录
2011/08/08 Javascript
jquery ajax 同步异步的执行 return值不能取得的解决方案
2012/01/08 Javascript
jquery实现类似淘宝星星评分功能有截图
2014/09/15 Javascript
JavaScript italics方法入门实例(把字符串显示为斜体)
2014/10/17 Javascript
JavaScript中的关联数组问题
2015/03/04 Javascript
javascript实现仿腾讯游戏选择
2015/05/14 Javascript
js检测用户输入密码强度
2015/10/22 Javascript
JavaScript转换与解析JSON方法实例详解
2015/11/24 Javascript
Bootstrap Table的使用总结
2016/10/08 Javascript
分享一道关于闭包、bind和this的面试题
2017/02/20 Javascript
Vue单页及多页应用全局配置404页面实践记录
2018/05/22 Javascript
vue移动端实现红包雨效果
2020/06/23 Javascript
VUE 全局变量的几种实现方式
2018/08/22 Javascript
JQuery特殊效果和链式调用操作示例
2019/05/13 jQuery
微信小程序实现滚动加载更多的代码
2019/12/06 Javascript
基于NodeJS开发钉钉回调接口实现AES-CBC加解密
2020/08/20 NodeJs
Using Django with GAE Python 后台抓取多个网站的页面全文
2016/02/17 Python
qpython3 读取安卓lastpass Cookies
2016/06/19 Python
Python 通过微信控制实现app定位发送到个人服务器再转发微信服务器接收位置信息
2019/08/05 Python
给你一面国旗 教你用python画中国国旗
2019/09/24 Python
Django 用户认证Auth组件的使用
2020/11/30 Python
Vans奥地利官方网站:美国原创极限运动潮牌
2018/09/30 全球购物
中式结婚主持词
2014/03/14 职场文书
《云房子》教学反思
2014/04/20 职场文书
大队干部竞选演讲稿
2014/04/28 职场文书
销售人才自我评价范文
2014/09/27 职场文书
大学开学典礼新闻稿
2015/07/17 职场文书
大学运动会加油稿
2015/07/22 职场文书
解除租赁合同协议书
2016/03/21 职场文书
Nginx开源可视化配置工具NginxConfig使用教程
2022/06/21 Servers