为了账号安全,请及时绑定邮箱和手机立即绑定

请问vuex 有没有像redux一样的debug工具?

请问vuex 有没有像redux一样的debug工具?

芜湖不芜 2019-08-14 14:10:42
vuex 有没有像redux一样的debug工具
查看完整描述

4 回答

?
慕容3067478

TA贡献1773条经验 获得超3个赞

区分 actions 和 mutations 并不是为了解决竞态问题,而是为了能用 devtools 追踪状态变化。

事实上在 vuex 里面 actions 只是一个架构性的概念,并不是必须的,说到底只是一个函数,你在里面想干嘛都可以,只要最后触发 mutation 就行。异步竞态怎么处理那是用户自己的事情。

vuex 真正限制你的只有 mutation 必须是同步的这一点(在 redux 里面就好像 reducer 必须同步返回下一个状态一样)。同步的意义在于这样每一个 mutation 执行完成后都可以对应到一个新的状态(和 reducer 一样),这样 devtools 就可以打个 snapshot 存下来,然后就可以随便 time-travel 了。如果你开着 devtool 调用一个异步的 action,你可以清楚地看到它所调用的 mutation 是何时被记录下来的,并且可以立刻查看它们对应的状态。

亲测:如果在mutation中做了异步操作,在dev-tools中会立即打印一个snapshot,而此时异步操作还没有执行完,此时的snapshot的信息是错误的。

而在action中做异步操作dev-tools会等等异步操作执行完才去打印mutation的一个snapshot,这样便于我们回查time-travel,查看在某个mutation里的变化。

查看完整回答
反对 回复 2019-08-24
?
慕尼黑的夜晚无繁华

TA贡献1864条经验 获得超6个赞

devtools 追踪状态变化。

事实上在 vuex 里面 actions 只是一个架构性的概念,并不是必须的,说到底只是一个函数,你在里面想干嘛都可以,只要最后触发 mutation 就行。异步竞态怎么处理那是用户自己的事情。vuex 真正限制你的只有 mutation 必须是同步的这一点(在 redux 里面就好像 reducer 必须同步返回下一个状态一样)。

同步的意义在于这样每一个 mutation 执行完成后都可以对应到一个新的状态(和 reducer 一样),这样 devtools 就可以打个 snapshot 存下来,然后就可以随便 time-travel 了。

查看完整回答
反对 回复 2019-08-24
?
aluckdog

TA贡献1847条经验 获得超7个赞

this.increment({ amount: 10 }) 或 this.add({ amount: 10 })
以例子中method的increment方法为例:
increment(...args){
return this.$store.dispatch.apply(this.$store,['incrememt'].concat(args))
}



查看完整回答
反对 回复 2019-08-24
  • 4 回答
  • 0 关注
  • 843 浏览
慕课专栏
更多

添加回答

举报

0/150
提交
取消
意见反馈 帮助中心 APP下载
官方微信