一般,咱们在使用vue编写页面时,会须要使用vuex在组件间传递(或者说共同响应)同一个数据的变化。例如:用户的登陆信息。html
下面,咱们使用传递用户登陆信息的例子来一步步解决这个问题。vue
首先,咱们的第一个问题是:我在一个组件(例如登陆组件页面)中登陆了后,其它页面要怎么获取和响应这个变化?(就是这么小白,/(ㄒoㄒ)/~~)git
这个答案就是使用vuex啦,在中文版的文档中有这样一句话:github
而这里的计算属性就是咱们的伟大的computed属性啦~vuex
(至于前面的经过mutation之类的把数据存入vuex中的过程就省略了,你们上网搜一下例子一大堆,切忌作伸手党哦~)htm
至于用在咱们的用户登陆的例子中就像是下面这样:blog
这样咱们就能够在页面根据用户信息响应式地显示内容了。事件
那么,咱们的第二个问题来了:我是获取到了vuex中的用户信息,可是我一刷新就没有了!!怎么办??在线等!十万火急!!文档
这个答案就是使用localStorage啦。(了解过html 5的同窗应该都知道它,这里我就不科普了。)it
一开始我虽然知道能够用localStorage,可是对于使用的逻辑有点乱,因此在这里记一下。
一、在vuex获取到用户信息时(例:state.user_id = user_info.user_id),同时把这个信息存入localStorage(Lockr.set('user_id', state.user_id) 这个Lockr是我用了一个叫Lockr的东西,其实它就是localStorage而已,关于它详细的请看https://github.com/tsironis/lockr);
二、咱们定义一个mutation方法,再次把数据从localStorage传给state;
三、咱们的问题发生在页面刷新时,可能不少同窗就会去想在监听页面刷新事件时触发上面第2步的那个方法。其实不用这么麻烦,在computed属性时,只要咱们判断一下用户信息是否为空,为空时调用第2步的那个方法就行了,而后咱们把这个state return给那个响应属性就行了;
四、至于为何这么麻烦在state和localStorage中传来传去,是由于state的值刷新后会没了,而localStorage的值不能响应式地变化(Vue 仅能够对其管理的数据作响应式处理,能够理解为 data 中的数据,localStorage 并不在 Vue 的管理下,天然不会有响应特性);
下面直接上computed处的代码:
以上就是使用localStorage解决vuex的state的值在刷新以后没有了这个问题的方法。
方法二:
在mount里面commit一次