vuex-学习笔记

前言

用过vue的同学应该都知道在vue里有个状态管理器,其实一开始我对vuex还不是很理解,甚至还不知道怎么用,今天就来聊聊vuex这东西,也帮助下新手了解下vuex,如果文中出现了理解有误的地方,还希望能够指出,一同进步,谢谢~

什么是vuex

以下是vuex官网给出的解释

Vuex 是一个专为 Vue.js 应用程序开发的状态管理模式。它采用集中式存储管理应用的所有组件的状态,并以相应的规则保证状态以一种可预测的方式发生变化。Vuex 也集成到 Vue 的官方调试工具 devtools extension,提供了诸如零配置的 time-travel 调试、状态快照导入导出等高级调试功能。

我的理解简言之就是

vuex是一个状态共享管理器,多用于多组件之间的状态共享以及数据共享(并非唯一的选择),再简单点就是一个实时响应的缓存

vuex和localStorage的区别

上文也提到了vuex可以相当于一个缓存,也许有的同学在使用vuex的时候也会觉得,为什么不使用localstorage来的方便(我自己当初也这么觉得的,哈哈哈)?

不过确实,如果只是单单进行一个多组件之间的数据共享的话,那么绝大多数情况下,localStorage确实能够满足使用,但是别忘了,vuex可不只是能够进行数据共享,还能做些localStorage无法做到的事儿

比如有这么一个业务场景,比如在根组件app.vue下(或者其他组件也行)有个我们已经写好的分享组件shareComponents.vue,然后我在子组件a.vueb.vue中各有一个按钮,当我点击这个按钮的时候分享组件shareComponents.vue就会弹出显示。

然后我将分享组件shareComponents.vue的显示和隐藏状态存到vuexstate中去,那么我在a.vueb.vue组件中只要操作vuex的这个state就行了,因为vuex的实时状态响应机制,只要vuex中的state一改变,那么只要其他组件里有这个共享的值时,都会实时改变。

如果我们使用localStorage的话,我们先将控制shareComponents.vue显示隐藏状态的值存入localStorage,然后在子组件a.vueb.vue中的点击事件去修改缓存中的值,那么结果会是什么?

缓存中的值是改变了,但是你会发现分享组件shareComponents.vue并没有弹出,这是为什么?原因其实很简单,我在这里修改了缓存中的值,但是在我要使用的地方需要重新getItem(localStorage API)后才能得到修改后的值,也就是localStorage并不具有实时性

这是vuexlocalStorage不同区别的一点
还有一点就是localStorage具有永久性,我们都知道,使用localStorage进行本地存储的时候,除非用户手动进行清理,否则缓存会一直存在本地当中

而反观vuex,每当页面重新刷新的时候,vuex就会重置所有的state状态为初始状态,这应该算是vuex的一个小缺点

如何解决vuex页面刷新重置所有状态的问题

  • 配合localStorage
    在我们操作vuexstate的同时,将对应的状态也缓存到localStorage中,然后在state中优先获取缓存,这样可以避免页面刷新,状态重置的问题,具体实现如下:

    // 我们先在state.js中定义状态值 以token为例
    import str from 'good-storage' #一个操作localStorage的库 具体可看    https://github.com/ustbhuangyi/storage
    const state = {
      ...
      token: str.get('token') ? str.get('token') : ''
    }
    export default state
    

    然后我以登录为示例,登录成功,获取token

    <template>
    ...
    // 省略html片段结构
    </template>
    <script>
    import str from 'good-storage'
    export default {
      methods: {
        login () {
          ...
          // 省略一些代码逻辑
          login(this.userInfo).then(res => {
             console.log('登录成功')
             str.set('token', res.data.token)  #将token存入缓存
             this.SET_TOKEN(res.data.token)  #这里就是将token存入state中 涉及到了mutation操作state 之后会说
          }, err => {
                ...
          })
        }
      }
    }
    </script>
    

    虽然有些麻烦,每次操作state的同时还得缓存一次,不过这也是一种解决方式了

  • 使用其他已经结合vuexlocalStorage的工具
    因为第一种方法还得做一次缓存的操作,有时候确实会觉得很麻烦,尤其是state比较多的时候

    不过github上已经有不少人将两者结合变成一个插件的做法,这里推荐一个vuex-persistedstate

    这个插件会在你每次操作state的时候 都将整个state都存入缓存中去 从而避免我们进一次的缓存操作 也算是比较便捷

    唯一觉得有缺点的是 如果要重置state状态的话 会比较麻烦

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 203,098评论 5 476
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 85,213评论 2 380
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 149,960评论 0 336
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,519评论 1 273
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,512评论 5 364
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,533评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,914评论 3 395
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,574评论 0 256
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,804评论 1 296
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,563评论 2 319
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,644评论 1 329
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,350评论 4 318
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,933评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,908评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,146评论 1 259
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 42,847评论 2 349
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,361评论 2 342

推荐阅读更多精彩内容

  • vuex学习笔记 vuex是什么? Vuex 是一个专为 Vue.js 应用程序开发的状态管理模式。它采用集中式存...
    EL_PSY_CONGROO阅读 766评论 0 0
  • Vuex 是什么? ** 官方解释:Vuex 是一个专为 Vue.js 应用程序开发的状态管理模式**。它采用集中...
    Rz______阅读 2,295评论 1 10
  • vuex 状态管理器 作为应用中所有组件的中央储存 只能以预定的方式去操作状态 把所有组件共享的状态抽取出来作为全...
    一只大椰子阅读 786评论 0 1
  • 学习资源: https://vuex.vuejs.org/zh-cn/ 介绍 Vuex是为Vue.js应用程序开发...
    林_Han阅读 361评论 0 2
  • 在组会之前的定向很重要,有些要求必须要提前提出来,或者会上看到了,就问旁边的人甚至团队,为什么这样你可以允许?比如...
    Hi_张阅读 162评论 0 0