挑战全网最幽默的Vuex系列教程:第一讲 Vuex到底是什么鬼

简介: Vuex 是 Vue.js 的座驾,所以,如果还不懂Vue.js 的话,那还是先把 Vue.js 勾搭上了再带过来一起坐坐吧。当然,既然能够溜达到这里,想必跟 Vue.js 起码也已经是朋友了吧。

Vuex 是 Vue.js  的座驾,所以,如果还不懂Vue.js 的话,那还是先把 Vue.js  勾搭上了再带过来一起坐坐吧。当然,既然能够溜达到这里,想必跟 Vue.js  起码也已经是朋友了吧。


有点啰嗦,不要嫌弃,写教程也需要有点前戏,毕竟是第一次。


安装


关于 Vuex 的具体安装,就不在这里说了,这个官方还是比较清晰的,戳此进入。但是需要注意两点:


  • 在一个模块化的打包系统中,您必须显式地通过 Vue.use() 来安装 Vuex,比如:


import Vue from 'vue'
import Vuex from 'vuex'
Vue.use(Vuex)  // 必须调用此函数来注入 Vuex


  • 当使用全局 script 标签引用 Vuex 时,就不用那么麻烦了,直接引用进来就好,但要注意引用的先后顺序,如下:


// 在 Vue 之后引入 vuex 会进行自动安装
<script src="/path/to/vue.js"></script>
<script src="/path/to/vuex.js"></script>


虽然 script 的方式看起来比较自动化,但是接触得多了,你就会明白模块化其实才是我们的最佳姿势。


揭开 Vuex 的神秘面纱


拿到一个工具,我们第一时间需要弄明白的,就是这个工具到底能够帮助我们解决什么问题。比如锤子,砸得了鸡蛋打得了电话,比如苹果,不但能吃还能玩。那么 Vuex 呢,如果把 Vue.js 比喻成路人(走路的人)的话,那么 Vuex 就是他的桑塔纳,如果他想去隔壁买包烟,那走过去就行了,开个车过去反而是一种负担,但是如果他想去几十公里的学校采花,那桑塔纳就得派上用场了,不然等他走过去,可能花儿都谢了。


当然,类比只是为了告诉我们 Vuex 的价值所在,那么在具体在实际的应用中,它能干什么?什么时候才需要翻它的牌呢?


我们先来看一段官方代码:


new Vue({
  // state  数据源
  data () {
    return {
      count: 0
    }
  },
  // view  视图
  template: `
    <div>{{ count }}</div>
  `,
  // actions  事件
  methods: {
    increment () {
      this.count++
    }
  }
})


这是一个很简单的增长型计数功能页面,和 Vue.js 有一腿的,应该秒懂。通过事件 increment,实现 count 增长,然后渲染到界面上去。


这种方式其实就跟走路买烟一样,属于短途效应,官方称作为「单向数据流」,很好理解。



但是,情况变了,现在有两个页面 A 和 B,还有以下两个要求:


  • 要求它们都能对 count 进行操控。


  • 要求 A 修改了 count 后,B 要第一时间知道,B 修改后,A 也要第一时间知道。


怎么办?稍微有点开发经验的,就能够很容易的想到,把数据源 count 剥离开来,用一个全局变量或者全局单例的模式进行管理,这样不就在任何页面都可以很容易的取到这个状态了。


是啊,这尼玛就是 Vuex 背后的思想啊,它干的就是这个事情。是不是有一种被 Vuex 这个高大上的名号所坑害的感觉,不就是全局模型吗,不用它也同样可能搞定嘛。


是的,也可以搞定,就像没有桑塔纳,你也可以去学校看花一样,只是经历的过程不一样了。


Vuex 的目的是为了管理共享状态,为了达到这个目的,它制定了一系列的规则,比如修改数据源 state、触发 actions 等等,都需要遵循它的规则,以此来达到让项目结构更加清晰且易于维护的目的。


那么我们再来看看官方的描述:


Vuex 是一个专为 Vue.js 应用程序开发的状态管理模式。它采用集中式存储管理应用的所有组件的状态,并以相应的规则保证状态以一种可预测的方式发生变化。


有没有瞬间清晰多了。


什么时候翻 Vuex 的牌


其实了解了 Vuex 要干的活以后,什么时候翻牌,那就容易选择得多了。就像前面的类比一样,去隔壁买包烟,你还开个桑塔纳,找停车位的时间,烟都抽完了。


所以,我们要根据项目的需要,来衡量短期和长期的效益,如果不打算开发大型的单页应用,那 Vuex 可能还是你的一个负担。对于一些不大不小的项目,自己又懒得走,开车又觉得麻烦,那你骑个共享单车过去也行嘛。


这里的共享单车指代的是官方中的一个简单的 store 模式,其实就是一个单纯的全局对象。


关于全局对象和 Vuex 之间的区别,官方写得还是比较通俗易懂的:


Vuex 和单纯的全局对象有以下两点不同:


  1. Vuex 的状态存储是响应式的。当 Vue 组件从 store 中读取状态的时候,若 store 中的状态发生变化,那么相应的组件也会相应地得到高效更新。


  1. 你不能直接改变 store 中的状态。改变 store 中状态的唯一途径就是显式地提交 (commit) mutation。这样使得我们可以方便地跟踪每一个状态的变化,从而让我们能够实现一些工具帮助我们更好地了解我们的应用。


简单示例


// 如果在模块化构建系统中,请确保在开头调用了 Vue.use(Vuex)
const store = new Vuex.Store({
  state: {
    count: 0
  },
  mutations: {
    increment (state) {
      state.count++
    }
  }
})


每一个 Vuex 应用的核心就是 store(仓库)。store 基本上就是一个容器,它包含着你的应用中大部分的状态 (state)。


注意:如果 mutations 不知道是什么,没关系,后面会专门讲解到,可以单纯的理解为只能用它里面的方法来修改 state 中的数据。


store.commit('increment') // 调用 mutations 中的方法
console.log(store.state.count) // -> 1


为什么要这样设计的,官方也给出了具体的原因:


我们通过提交 mutation 的方式,而非直接改变 store.state.count,是因为我们想要更明确地追踪到状态的变化。这个简单的约定能够让你的意图更加明显,这样你在阅读代码的时候能更容易地解读应用内部的状态改变。此外,这样也让我们有机会去实现一些能记录每次状态改变,保存状态快照的调试工具。有了它,我们甚至可以实现如时间穿梭般的调试体验。


由于 store 中的状态是响应式的,在组件中调用 store 中的状态简单到仅需要在计算属性中返回即可。触发变化也仅仅是在组件的 methods 中提交 mutation。


如果最后一句话没看懂,没关系,下一章马上就会讲到。


PS


来点正经的,到这里,第一篇其实就已经写完了,当然,这里的内容都是我看了官方的教程后,自己的一个理解,如果有理解不到位的地方,欢迎拍砖。


转载声明:


作者:大宏说


原文链接: www.jianshu.com/p/120eaf503…


相关文章
|
29天前
|
开发框架 前端开发 JavaScript
【总结】React 的发展情况总结及大厂选择与新手看法
【总结】React 的发展情况总结及大厂选择与新手看法
|
4月前
|
缓存 移动开发 JavaScript
vue核心面试题汇总【查缺补漏】(一)
vue核心面试题汇总【查缺补漏】(一)
108 0
|
4月前
|
缓存 JavaScript 前端开发
vue核心面试题汇总【查缺补漏】(二)
vue核心面试题汇总【查缺补漏】(二)
|
4月前
|
JavaScript 前端开发 编译器
【VueConf 2022】尤雨溪:Vue的进化历程
【VueConf 2022】尤雨溪:Vue的进化历程
|
7月前
|
存储 JavaScript 数据管理
VUEX全网最详细讲解之一
VUEX全网最详细讲解之一
38 0
|
9月前
|
JavaScript 数据管理
Vuex的教学
在Vue中实现集中式状态(数据)管理的一个Vue插件,对vue应用中多个组件的共享状态进行集中式的管理(读/写),也是一种组件间通信的方式,且适用于任意组件间通信。
|
9月前
|
前端开发 JavaScript 小程序
react技术问题十问十答
react技术问题十问十答
57 0
|
9月前
|
缓存 前端开发
前端学习笔记202307学习笔记第五十九天-react源码-双缓存技术
前端学习笔记202307学习笔记第五十九天-react源码-双缓存技术
36 0
|
存储 缓存 JavaScript
小白学前端之TypeScript使用Vuex 4.0|8月更文挑战
官方介绍:Vuex 是一个专为 Vue.js 应用程序开发的状态管理模式。它采用集中式存储管理应用的所有组件的状态,并以相应的规则保证状态以一种可预测的方式发生变化。
168 0
|
缓存 JavaScript API
下一代vue状态管理工具 pinia,快来看看这个可爱的菠萝吧
下一代vue状态管理工具 pinia,快来看看这个可爱的菠萝吧