黄子涵

查漏补缺——说说Vuex的commit函数

问题

如题所示

答案

相关源码如下:

initComputeTime: ({commit}) => {
commit('GET_RUNTIME_INTERVAL');
},

vuex直接修改state 与 用commit提交mutation来修改state的差异

这里commit函数的作用是提交到mutation修改state,还有以下源码:

const mutations = {
GET_RUNTIME_INTERVAL: (state) => {
if (!timer || !state.runTimeInterval) {
clearInterval(timer)
timer = setInterval(() => {
state.runTimeInterval = getTimeInterval(runAt);
}, 1000);
}
}
}

在mutation属性里面有个GET_RUNTIME_INTERVAL函数,这个函数刚好是是commit函数的参数,当我们调用commit函数时,应该触发了mutation属性的这个GET_RUNTIME_INTERVAL函数,当GET_RUNTIME_INTERVAL函数被调用,它的参数,也就是state就会被函数里的内容而修改。

posted @   黄子涵  阅读(749)  评论(0编辑  收藏  举报
相关博文:
阅读排行:
· TypeScript + Deepseek 打造卜卦网站:技术与玄学的结合
· Manus的开源复刻OpenManus初探
· AI 智能体引爆开源社区「GitHub 热点速览」
· 三行代码完成国际化适配,妙~啊~
· .NET Core 中如何实现缓存的预热?
点击右上角即可分享
微信分享提示