美文网首页vueVueVUEX
Vuex小案例(带你5分钟入门)

Vuex小案例(带你5分钟入门)

作者: 七分热度丶 | 来源:发表于2019-11-24 23:59 被阅读0次
首先我们要知道我们为什么要用Vuex?

当多个状态或者说是数据分散在不同组件的各个角落,有大量状态或者数据需要相互间传递,如果都放在后台,统一去后台获取,则网络开销会很大,多层嵌套组件间就需要vuex这样的解决方案,公共数据托管在state里,不同组件都可以使用。

让我们先看这张图,


image.png

中间的那个组件(counter.vue)和最下面那组件(amount.vue)是兄弟组件,要让counter.vue组件和amount.vue组件实现数据共享,点击增加按钮,amount组件的值会随输入框的内容变化而变化,下面让我们想想思路,没学vuex我们的思路是这样的,让counter.vue通过$emit触发一个方法把值传给父组件,然后通过父组件把值传给amount.vue用props接收,这样就可以实现数据的传值共享了。但是如果需要很多个组件实现数据共享呢?这样就要一直重复这个步骤。这是我们不允许的,此时我们可以用vuex!

counter.vue
<template>
  <div>
    <input type="button" value="减少" @click="remove">
    <input type="button" value="增加" @click="add">
    <br>
    <input type="text" v-model="$store.state.count">
  </div>
</template>

<script>
export default {
  data() {
    return {
    };
  },
  methods: {
    add() {
      // 千万不要这么用,不符合 vuex 的设计理念
      // this.$store.state.count++;
      this.$store.commit("increment");
    },
    remove() {
      this.$store.commit("subtract", { c: 3, d: 1 });
    }
  },
};
</script>

amount.vue
<template>
  <div>
    <!-- <h3>{{ $store.state.count }}</h3> -->
    <h3>{{ $store.getters.optCount }}</h3>
    
  </div>
</template>

<script>
</script>
main.js
// 入口文件
import Vue from 'vue'
// 配置vuex的步骤
// 1. 下载cnpm i vuex -S 
// 2. 导入包
import Vuex from 'vuex'
// 3. 注册vuex到vue中
Vue.use(Vuex)
// 4. new Vuex.Store() 实例,得到一个 数据仓储对象
var store = new Vuex.Store({
  state: {
    // 大家可以把 state 想象成 组件中的 data ,专门用来存储数据的
    // 如果在 组件中,想要访问,store 中的数据,只能通过 this.$store.state.xxx(数据的键名) 来访问
    count: 0
  },
  mutations: {
    // 注意: 如果要操作 store 中的 state 值,只能通过 调用 mutations 提供的方法,才能操作对应的数据,不推荐直接操作 state 中的数据,因为 万一导致了数据的紊乱,不能快速定位到错误的原因,因为,每个组件都可能有操作数据的方法;
    increment(state) {
      state.count++
    },
    // 注意: 如果组件想要调用 mutations 中的方法,只能使用 this.$store.commit('方法名')
    // 这种 调用 mutations 方法的格式,和 this.$emit('父组件中方法名')
    subtract(state, obj) {
      // 注意: mutations 的 函数参数列表中,最多支持两个参数,其中,参数1: 是 state 状态; 参数2: 通过 commit 提交过来的参数;
      console.log(obj)
      state.count -= (obj.c + obj.d)
    }
  },
  getters: {
    // 注意:这里的 getters, 只负责 对外提供数据,不负责 修改数据,如果想要修改 state 中的数据,请 去找 mutations
    optCount: function (state) {
      return '当前最新的count值是:' + state.count
    }
    // 经过咱们回顾对比,发现 getters 中的方法, 和组件中的过滤器比较类似,因为 过滤器和 getters 都没有修改原数据, 都是把原数据做了一层包装,提供给了 调用者;
    // 其次, getters 也和 computed 比较像, 只要 state 中的数据发生变化了,那么,如果 getters 正好也引用了这个数据,那么 就会立即触发 getters 的重新求值;
  }
})


import App from './App.vue'

const vm = new Vue({
  el: '#app',
  render: c => c(App),
  store // 5. 将 vuex 创建的 store 挂载到 VM 实例上, 只要挂载到了 vm 上,任何组件都能使用 store 来存取数据
})

总结:

  1. state中的数据,不能直接修改,如果想要修改,必须通过 mutations
  2. 如果组件想要直接 从 state 上获取数据: 需要 this.$store.state.xxx(数据的键名)
  3. 如果 组件,想要修改数据,必须使用 mutations 提供的方法,需要通过 this.$store.commit('方法的名称', 唯一的一个参数)
  4. 如果 store 中 state 上的数据, 在对外提供的时候,需要做一层包装,那么 ,推荐使用 getters, 如果需要使用 getters ,则用 this.$store.getters.方法名

以上这个vuex案例就讲完了,写的很清楚,有注释。记得给个订阅哦!

相关文章

网友评论

    本文标题:Vuex小案例(带你5分钟入门)

    本文链接:https://www.haomeiwen.com/subject/somrwctx.html