V2EX = way to explore
V2EX 是一个关于分享和探索的地方
Sign Up Now
For Existing Member  Sign In
推荐关注
Meteor
JSLint - a JavaScript code quality tool
jsFiddle
D3.js
WebStorm
推荐书目
JavaScript 权威指南第 5 版
Closure: The Definitive Guide
noahlam

vuex 其实超简单,只需 3 步

  •  
  •   noahlam · May 18, 2018 · 3214 views
    This topic created in 2901 days ago, the information mentioned may be changed or developed.

    前言

    之前几个项目中,都多多少少碰到一些组件之间需要通信的地方,而因为种种原因, event bus 的成本反而比 vuex 还高, 所以技术选型上选用了 vuex, 但是不知道为什么, 团队里的一些新人一听到 vuex,就开始退缩了, 因为 vuex 很难? 真的很难吗? 今天我们用简单的 3 步来证明一下,vuex 有多简单.

    纯属个人经验,难免有不正确的地方,如有发现,欢迎指正!

    这是一个针对新手的入门级教程、入门级教程、入门级教程

    第零步

    新建一个 vue 项目,安装 vuex,这里不做过多介绍,能点进来的,默认你具备这些技能 ^_^

    第一步

    新建一个.js 文件,名字位置任意,按照惯例,建议在/src/store 目录下(没有的话自己新建一个呗)

    文件位置 /src/store/index.js

    // 引入 vue 和 vuex
    import Vue from 'vue'
    import Vuex from 'vuex'
    
    // 这里需要 use 一下,固定写法,记住即可
    Vue.use(Vuex)
    
    // 直接导出 一个 Store 的实例
    export default new Vuex.Store({
      // 类似 vue 的 data
      state: {
        name: 'oldName'
      },
      // 类似 vue 里的 mothods(同步方法)
      mutations: {
        updateName (state) {
          state.name = 'newName'
        }
      }
    })
    

    代码看起来稍微有那么一点点多,不过看起来是不是很熟悉? 跟普通的 vue 没多大差别嘛. 这一步其实就是新建一个 store,但是我们还没在项目中使用.

    第二步

    在入口文件引入上述文件, 并稍微改一下传给 new Vue()的参数,新增的行后面有备注

    文件位置 /src/main.js (vue-cli 自动生成的入口,如果你能不用脚手架,那么也就不需要我说明了)

    import Vue from 'vue'
    import App from './App'
    import vuexStore from './store'   // 新增
    
    new Vue({
      el: '#app',
      store:vuexStore                 // 新增
      components: { App },
      template: '<App/>'
    })
    

    Tip: import store from './store' 后面的地址,就是上面我们新建那个文件的位置(/src/store/index.js), 因为我这里是 index.js,所以可以省略.

    第三步

    以上 2 步,其实已经完成了 vuex 的基本配置,接下来就是使用了

    文件位置 /src/main.js (同样是 vue-cli 生成的 app.vue,这里为了方便演示,我去掉多余的代码)

    <template>
      <div>
        {{getName}}
        <button @click="changeName" value="更名">更名</button>
      </div>
    </template>
    
    <script>
    import HelloWorld from './components/HelloWorld'
    
    export default {
      computed:{
        getName(){
          return this.$store.state.name
        }
      },
      methods:{
        changeName () {
          this.$store.commit('updateName')
        }
      }
    }
    </script>
    

    这里就是一个很普通的 vue 文件了,有区别的地方是这里我们需要用 computed 属性去获取 store 里的 "data"

    还有就是我们要改变数据的话,不再用 this.xxx = xxx 改成 this.$store.commit('updateName')

    总结

    你可能会觉得,上例这样做的意义何在,为何不直接用 vue 的 data 跟 methods?

    上例只是为了简单讲解如何使用 vuex,所以简化了一些流程,试想一下,如果你有这样一个页面: 一共嵌套了 10 层组件(即子组件里面还有子子组件,子子组件下面还有子子子组件,以此类推 10 层) 然后最后一层组件一个数据改变了,要通知第一层组件的时候,我们只需在最底层组件里this.$store.commit(), 然后再最外层组件上用 computed 属性获取对应的值,就能做到实时更新.无需层层$emit 上去.

    最后

    本来想在最后再扩展一下 getter,action+dispatch,模块化等等,不过为了对得起这个标题, 只好放在 下一篇:vuex 其实超简单,喝完这 3 步,还有 3 步

    如果觉得本文对您有用,请给本文的github加个 star,万分感谢

    另外,github上还有其他一些关于前端的教程和组件,有兴趣的童鞋可以看看,你们的支持就是我最大的动力。

    No Comments Yet
    About   ·   Help   ·   Advertise   ·   Blog   ·   API   ·   FAQ   ·   Solana   ·   999 Online   Highest 6679   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 28ms · UTC 19:34 · PVG 03:34 · LAX 12:34 · JFK 15:34
    ♥ Do have faith in what you're doing.