官方文档:https://vuex.vuejs.org/zh/guide/
1.定义state变量
2.只有 mutations下面定义的mutation方法 能动 State,改变State。Vuex 规定必须使用 store.commit 来触方法
总结,想要改变一个 State,必须要定义一个mutation函数去改变它,想要执行mutation函数必须使用 store.commit 来触发/调用
2.1:为什么要通过提交 mutation 的方式来改变状态数据?
是因为我们想要更明确地追踪到状态的变化,如果你随便在一个地方就改了state.count这个属性的状态,项目大了的话,那就很难明确地追踪到状态的变化
定义mutation方法之后,想要追踪直接在方法里面调试记录就行了;
3、actions是干嘛的?直接用mutation改状态不就行了,还多此一举用actions去执行mutation去改State
首先你要知道mutation必须是同步函数(官方规定的,也就是函数里面不能有异步操作),所以想要异步操作就要action函数来处理,这就需要actions了;注意action提交的是 mutation,而不是直接变更状态
4、提交载荷是啥意思 ?蒙蔽中。。啥生涩的词语;
就是官方给它取了一个高大上的名字:载荷(payload),下面的commit第二个参数就是载荷,大多数情况下,载荷是一个对象,也就是传一个对象进去;
5、vuex 的dispatch和commit提交mutation的区别
说白了就是在mutations下面定义的函数方法,就用commit触发执行,在actions下面定义的方法就用dispatch触发执行
store.commit('你的mutation方法),所以commit就是触发mutations下面定义的方法(注意,我们不能直接 store.mutations.increment()来调用,Vuex 规定必须使用 store.commit 来触发对应 type 的方法:)
store.dispatch(‘你的action方法’), 所以dispatch就是触发actions下面定义的方法
可以试一试用dispatch调用mutations下面定义的方法,会不会报错反正我没试过;
6、vuex和localstorage的区别
1)最重要的区别:vuex存储在内存,localstorage则以文件的方式存储在本地
2)应用场景:vuex用于组件之间的传值,localstorage则主要用于不同页面之间的传值。
3)永久性:当刷新页面时vuex存储的值会丢失,localstorage不会。
4)localStorage用来存储需要持久化的数据,vuex启动时直接从localstorage获取持久化的数据就实现了应用的持久化的需求
7、为什么要使用vuex而不使用全局变量比如window;
用全局变量初期还好,如果项目复杂你定义的window各种变量就很乱,你就要对这个全局变量进行封装管理优化,更方便的调用,到最后你发现这个过程实际就是重复的造轮子,自己封装成了个vuex,何必呢;
csdn博客:https://blog.csdn.net/qq_37759901/article/details/117438760?spm=1001.2014.3001.5502