mutations vuex 调用_Vuex中的Mutations的具体使用方法

mutations vuex 调用_Vuex中的Mutations的具体使用方法在 Vuex 中 store 数据改变的唯一方法就是提交 mutations mutations 里面装着一些改变数据方法的集合 这是 Vuex 设计很重要的一点 就是把处理数据逻辑方法全部放在 mutations 里面 使得数据和视图分离 Mutations 使用 Vuex 中的 mutations 非常类似于事件 每个 mutations 都有一个字符串的事件类型 type 和一个回调函数 handl

在 Vuex 中 store 数据改变的唯一方法就是提交 mutations。mutations里面装着一些改变数据方法的集合,这是Vuex 设计很重要的一点,就是把处理数据逻辑方法全部放在 mutations 里面,使得数据和视图分离。

Mutations使用

Vuex 中的 mutations 非常类似于事件,每个 mutations 都有一个字符串的事件类型(type)和一个回调函数(handler),也可以理解为{type:handler()},这和订阅发布有点类似。先注册事件,当触发响应类型的时候调用handker(),调用type的时候需要用到store.commit方法。

示例:

这个回调函数会接受state 作为第一个参数:

const store = new Vuex.Store({

state: {

count: 1

},

mutations: {

// 事件类型 type 为 increment

increment (state) {

// 变更状态

state.count++

}

}

})

我们不能直接使用store.mutations.increment() 来调用,Vuex 规定必须使用 store.commit 来触发对应 type 的方法:

store.commit(‘increment’)

提交载荷(Payload)

载荷简单的理解就是往 handler(state) 中传参 handler(state, pryload) 。

示例:

大多数情况下,载荷是一个对象:

mutations: {

// 提交荷载

increment (state, payload) {

state.count += payload.amount

}

}

提交荷载有两种方式:

// 把载荷和type分开提交

store.commit(‘increment’, {

amount: 10

})

// 整个对象都作为载荷传给mutation函数

store.commit({

type: ‘increment’,

amount: 10

})

我们可以根据自己的喜好来选择使用哪种提交方式。

commit

我们可以在组件中使用 this.$store.commit(‘xxx’) 提交 mutations。

示例:

或者可以使用 mapMutations 辅助函数将组件中的 methods 映射为 store.commit 调用(需要在根节点注入 store)。

示例:

在使用mapMutations 辅助函数之前同样需要先引入:

import { mapMutations } from ‘vuex’

export default {

computed:{

count(){

return this.$store.state.count

}

},

methods:{

…mapMutations([

‘increment’,

‘decrement’

])

}

}

Mutations 需遵守 Vue 的响应规则

Vuex 的 store 中的状态是响应式的,所以当我们变更状态时,监视状态的 Vue 组件也会自动更新。

这也意味着 Vuex 中的 mutations 也需要与使用 Vue 一样遵守一些注意事项,如下所示:

最好提前在 store 中初始化好所有所需属性。

当需要在对象上添加新属性时,应该使用 Vue.set(obj, ‘newProp’, 123),或者以新对象替换老对象。例如利用对象展开运算符可以写成:state.obj = {…state.obj, newProp: 123 }。

使用常量替代 Mutations 事件类型

使用常量替代 mutations 事件类型在各种 Flux 实现中是很常见的模式。这样可以使 linter 之类的工具发挥作用,同时把这些常量放在单独的文件中可以让你的代码合作者对整个 app 包含的 mutations 一目了然:

// mutation-types.js

export const SOME_MUTATION = ‘SOME_MUTATION’

store.js 文件内容如下所示:

// store.js

import Vuex from ‘vuex’

import { SOME_MUTATION } from ‘./mutation-types’

const store = new Vuex.Store({

state: { … },

mutations: {

// 使用 ES2015 风格的计算属性命名功能来使用一个常量作为函数名

[SOME_MUTATION] (state) {

// mutate state

}

}

})

我们知道mutation 是通过store.commit(‘increment’)的方式调用的,其中increment方法是以字符串的形式代入。如果项目小,一个人开发的话倒还好,但是项目大了,编写代码的人多了,那就麻烦了,因为需要 commit 的方法一多,就会显得特别混乱,而且以字符串形式代入的话,一旦出了错,很难排查。

所以,在需要多人协作的大型项目中,最好还是用常量的形式来处理 mutation。

必须是同步函数

我们要记住的是,Mutation 必须是同步函数。

因为我们之所以要通过提交 mutation 的方式来改变状态数据,是因为我们想要更明确地追踪到状态的变化。如果是类似下面这样异步的话:

mutations: {

someMutation (state) {

api.callAsyncMethod(() => {

state.count++

})

}

}

我们就不知道什么时候状态会发生改变,所以也就无法追踪了,这与 Mutation 的设计初心相悖,所以强制规定它必须是同步函数。

store.commit(‘increment’) // 任何由’increment’导致的状态变更都应该在此刻完成

到此这篇关于Vuex中的Mutations的具体使用方法的文章就介绍到这了,更多相关Vuex Mutations内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/223947.html原文链接:https://javaforall.net

(0)
上一篇 2026年3月17日 下午1:03
下一篇 2026年3月17日 下午1:04


相关推荐

  • Android视图与布局整理

    Android视图与布局整理

    2021年9月30日
    33
  • 解决IDEA插件安装慢、超时、不成功问题[通俗易懂]

    解决IDEA插件安装慢、超时、不成功问题[通俗易懂]解决IDEA插件安装慢、超时、不成功问题1.修改本地hosts文件,打开文件位置:Windows系统Hosts文件路径:C:\Windows\System32\drivers\etc\hosts用工具打开hosts文件2.打开国内插件的节点IP地址http://tool.chinaz.com/speedtest/plugins.jetbrains.com在检测结果中选择一个相对耗时少的IP地址,因为比较快然后按照第一步在hosts文件里加上即可,然后保存(需要以管理员身份)3.重

    2022年5月11日
    177
  • vue使用echarts引用示例

    vue使用echarts引用示例ECharts 支持多种下载方式 从 GitHub 获取 从 npm 获取 从 CDN 获取从 npm 获取 npminstallec 从 CDN 获取推荐从 jsDelivr 引用 echarts 从 GitHub 获取 apache echarts 项目的 release 页面可以找到各个版本的链接 点击下载页面下方 Assets 中的 Sourcecode 解压后 dist 目录下的 echarts js 即为包含完整 ECharts 功能的文件

    2026年3月16日
    2
  • python爬虫全解

    python爬虫全解一、爬虫基础简介什么是爬虫:-通过编写程序,模拟浏览器上网,然后让其去互联网上抓取数据的过程。爬虫的价值:-实际应用-就业爬虫究竟是合法还是违法的?-在法律中是不被禁止-具有违法风险-

    2022年7月3日
    25
  • H5移动端开发学习总结

    H5移动端开发学习总结对于移动端开发而言,为了做到页面高清的效果,视觉稿的规范往往会遵循以下两点:1.首先,选取一款手机的屏幕宽高作为基准(现在一般选取iphone6的375×667)。之前项目中也用到过iphone5的320×568。2.对于retina屏幕(如:dpr=2),为了达到高清效果,视觉稿的画布大小会是基准的2倍,也就是说像素点个数是原来的4倍(对iphone6而言:原先的375×667,就会变成

    2022年6月21日
    46
  • java中的invoke方法_java中的反射,invoke方法详解

    java中的invoke方法_java中的反射,invoke方法详解展开全部就是调用类中的方法e68a843231313335323631343130323136353331333365646239,最简单的用法是可以把方法参数化,invoke(class,method)比如你Test类里有一系列名字相似的方法setValue1、setValue2等等。可以把方法名存进数组v[],然后循环里invoke(test,v[i]),就顺序调用了全部setValue如:…

    2022年6月3日
    36

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号