查漏补缺——说说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就会被函数里的内容而修改。
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· TypeScript + Deepseek 打造卜卦网站:技术与玄学的结合
· Manus的开源复刻OpenManus初探
· AI 智能体引爆开源社区「GitHub 热点速览」
· 三行代码完成国际化适配,妙~啊~
· .NET Core 中如何实现缓存的预热?