vue mutations与actions的区别
关于 mutations与actions的区别,网上有很多文章,大多是照着vue.js的教程再来一波!!因为最近接手vue项目,自己之前vue的知识点掌握也不深,就此机会把这个知识点再深挖一下。
使用vuex进行状态管理时,使用mutations来进行state的状态变更。其中一个要求就是mutations中的代码必需时同步的,因此要想在其中包含异步操作是不合适的。如下代码:
const app = {
state: {
//直接访问state中的元素,可获得元素的值,但是不利于封装
//并且在访问是如果store.count的访问方式也不方便
//mapStore方便快速将store.count映射到计算属性,但本质上还是直接访问元素的值,无法达到getters封装取值时二次加工的效果
count: 100
},
getters: {
//对state元素进行取值进行封装,可以方便实现在取值时的各种运算需求
//mapGetters与mapState类型,实现快速将getters映射到计算属性
getCount: state => {
return state.count > 100 ? true : false
}
},
mutations: {
//对state元素值的写入进行封装,可以方便实现在赋值时的各种运算需求
//mapMutations与mapState类型,实现快速将mutations映射到方法中methods
add(state, n) {
state.count += n
}
}
}
export default app
如上面的add中要根据n的奇偶性来异步request不同外部接口获取数据用于运算,此时mutation中就导致无法完成操作。因此在没有actions的概念下,我们只能将(根据n的奇偶性来异步request不同外部接口获取数据)其提前与add执行,然后将执行结果传给add来实现该目的。但这么做的结果是逻辑被拆开,逻辑松散化了。个人认为这就是mutations的短板,为了能将该短板补上,actions就横空出世了。
action中则可以按上面的逻辑执行,并最终提交的mutation add,瞬间海阔天空了!
//基础store配置信息
import Vue from 'vue' const app = {
state: {
//直接访问state中的元素,可获得元素的值,但是不利于封装
//并且在访问是如果store.count的访问方式也不方便
//mapStore方便快速将store.count映射到计算属性,但本质上还是直接访问元素的值,无法达到getters封装取值时二次加工的效果
count: 100
},
getters: {
//对state元素进行取值进行封装,可以方便实现在取值时的各种运算需求
//mapGetters与mapState类型,实现快速将getters映射到计算属性
getCount: state => {
return state.count > 100 ? true : false
}
},
mutations: {
//对state元素值的写入进行封装,可以方便实现在赋值时的各种运算需求
//mapMutations与mapState类型,实现快速将mutations映射到方法中methods
add(state, n) {
state.count += n
}
},
actions:{
aadd({commit},n){
if(n%2){
Vue.axios.get('http://127.0.0.1:8881/home/a').then(res=>{
console.log(res.data)
commit('add',res.data)
})
}
else{
Vue.axios.post('http://127.0.0.1:8881/home/b').then(res=>{
console.log(res.data)
commit('add',res.data)
})
}
}
}
}
export default app
这个就能在actions中顺利的执行ajax异步操作了,nice!
完整代码:
//main.js
import Vue from 'vue'
import App from './App.vue'
import Vuex from 'vuex'
import axios from 'axios'
import VueAxios from 'vue-axios'
import storeSetting from './strore' Vue.use(Vuex)
Vue.use(VueAxios, axios) const store = new Vuex.Store(storeSetting) new Vue({
store,
render: h => h(App),
}).$mount('#app')
// /store/index.js,基础store配置信息
//引入vue,方便调用axios
import Vue from 'vue' const app = {
state: {
count: 100
},
getters: {
getCount: state => {
return state.count > 100 ? true : false
}
},
mutations: {
add(state, n) {
state.count += n
}
},
actions:{
aadd({commit},n){
if(n%2){
Vue.axios.get('http://127.0.0.1:8881/home/a').then(res=>{
console.log(res.data)
commit('add',res.data)
})
}
else{
Vue.axios.post('http://127.0.0.1:8881/home/b').then(res=>{
console.log(res.data)
commit('add',res.data)
})
}
}
}
}
export default app
<template>
<div id="app">
<p><button @click="add">count</button></p>
</div>
</template> <script>
import setting from "./components/routes/nameview/Setting.vue";
import { mapState } from "vuex"; export default {
components: { setting },
name: "App",
methods: {
add(){
this.$store.dispatch('aadd',2)
}
}
};
</script>
vue mutations与actions的区别的更多相关文章
- vuex中mutations与actions的区别
要执行vuex中的函数,有两种方法: 1.commit,例如this.$store.commit("GETMODULESELECTLIST"); //mutations中的方法 2 ...
- Vuex入门实践(中)-多module中的state、mutations、actions和getters
一.前言 上一篇文章<Vuex入门实践(上)>,我们一共实践了vuex的这些内容: 1.在state中定义共享属性,在组件中可使用[$store.state.属性名]访问共享属性 2.在m ...
- vue和react之间的区别
1.Vue和React之间的区别 相同点: Vue和其他框架一样,都有组件开发和虚拟dom 都支持props进行父子组件之间的数据通信 都支持数据驱动视图,不直接操作真实dom 都支持服务器端的 渲染 ...
- vue 中 watch 和 watchEffect 区别
vue 中 watch 和 watchEffect 区别 * watch 需要先指明需要侦听的数据源,watchEffect 不需要,只要传入的函数带有依赖就会自动追踪. * watchEffect ...
- vue、React Nactive的区别(转载)
Vue与React的对比 Vue.js与React.js从某些反面来说很相似,通过两个框架的学习,有时候对一些用法会有一点思考,为加深学习的思索,特翻阅了两个文档,从以下各方面进行了对比,加深了对这两 ...
- vuex中的state、mutations 、actions 、getters四大属性如何使用
一.state (提供唯一的公共数据源) 方式1 在div中,$store.state.count 方式2 import {mapState} from 'vuex' computed:{ -mapS ...
- vue $mount 和 el的区别
两者在使用效果上没有任何区别,都是为了将实例化后的vue挂载到指定的dom元素中. 如果在实例化vue的时候指定el,则该vue将会渲染在此el对应的dom中,反之,若没有指定el,则vue实例会处于 ...
- vue中$mount与el区别
vue中的$mount和el两者在使用中没有什么区别,都是将实例化后的vue挂载到指定的DOM元素中 用法: 如果在实例化vue时指定el,则该vue将会渲染在el对应的DOM中 反之 没有指定el, ...
- Vue路由钩子 afterEach beforeEach区别
vue-router作为vue里面最基础的服务,学习一段时间,对遇到的需求进行一些总结 使用vue-cli作为开发前提 vue-router已经配置好了 路由写法 routes: [ { path ...
- Vue 中computed 与 methods 区别
1.示例 <!DOCTYPE html> <html lang="zh"> <head> <meta charset="UTF- ...
随机推荐
- python,opencv-python人脸识别,并且发邮件对镜头前未知人员进行报警
我们在任意一个硬盘的根目录下创建一个Code-project文件夹 在该文件夹下分别创建C-project和Python-project文件夹 在Python-project文件夹下创建face re ...
- dev-c++ 使用教程
Dev C++ 支持单个源文件的编译,如果你的程序只有一个源文件(初学者基本都是在单个源文件下编写代码),那么不用创建项目,直接运行就可以:如果有多个源文件,才需要创建项目. 一.新建源文件 1.通过 ...
- GitHub Desktop安装与使用教程
一.安装 1.下载 下载地址 2.安装 下载之后GitHub Desktop是没有安装步骤的,而是开始安装之后,稍等片刻就安装成功了. 然后登陆个人GitHub账号就可以进行一下操作了. 二.新建仓库 ...
- python生成列表的时间复杂度
在刷题的时候,经常碰到需要生成非常大的邻接矩阵,往往我们都是用 list 存储,但是我在最近刷题的过程中就遇上了TLE的情况,原因就是生成邻接矩阵时间太花时间了. 先说结论:[ ]* n 比 [ fo ...
- VA01/VA02/VA03 销售订单根据定价和步骤校验权限隐藏价格(二)
1.文档说明 1.1.内容回顾 之前发表过相关文章<VA01/VA02/VA03 销售订单根据定价和步骤校验权限隐藏价格>,本篇文章对上一篇文章做补充说明. 第一篇文章是通过拥有权限,则隐 ...
- 超轻量级MP4封装方法介绍
liwen01 2023.12.17 前言 MP4是目前非常常用的一种视频封装格式,关于MP4的介绍资料也非常多.我们常用的封装库或工具有:ffmpeg,libmp4v2,GPAC,MP4.js,它们 ...
- @Value是个什么东西
对注解不了解的可以看一下: Java注解,看完就会用 首先我们要明确: @Value 是 Spring 框架的注解. 它有什么作用呢? 作用 @Value 通过注解将常量.配置文件中的值.其他bean ...
- 开心自走棋:使用 Laf 云开发支撑数百万玩家
先介绍一下开心自走棋 开心自走棋是一款剑与魔法的烧脑自走棋游戏.以著名的魔幻世界观为蓝本,采用了轻松可爱的画面风格,精致细腻的动画和特效来还原魔兽之战. 现在市面上自走棋游戏多是 PvP 玩法为主,而 ...
- 如何使用 Helm 在 K8s 上集成 Prometheus 和 Grafana|Part 2
在 Part 1 中,我们一起了解了什么是 Prometheus 和 Grafana,以及使用这些工具的前提条件和优势.在本部分,将继续带您学习如何安装 Helm 以及如何使用 Prometheus ...
- 2023-11-04:用go语言,如果n = 1,打印 1*** 如果n = 2,打印 1*** 3*** 2*** 如果n = 3,打印
2023-11-04:用go语言,如果n = 1,打印 1*** 如果n = 2,打印 1*** 3*** 2*** 如果n = 3,打印 1*** 3*** 2*** 4*** 5*** 6*** ...