目录
vuex使用注意细节

使用:

  1. 下包:npm install vuex –save
  2. 安装:import vue from ‘vue’
     import vuex from 'vuex'
    Vue.use(Vuex)
1
// 入口文件
2
import Vue from 'vue'
3
// 配置vuex的步骤
4
// 1. 运行 cnpm i vuex -S 
5
// 2. 导入包
6
import Vuex from 'vuex'
7
// 3. 注册vuex到vue中
8
Vue.use(Vuex)
9
// 4. new Vuex.Store() 实例,得到一个 数据仓储对象
10
var store = new Vuex.Store({
11
  state: {
12
    // 大家可以把 state 想象成 组件中的 data ,专门用来存储数据的
13
    // 如果在 组件中,想要访问,store 中的数据,只能通过 this.$store.state.*** 来访问
14
    count: 0
15
  },
16
  mutations: {
17
    // 注意: 如果要操作 store 中的 state 值,只能通过 调用 mutations 提供的方法,才能操作对应的数据,不推荐直接操作 state 中的数据,因为 万一导致了数据的紊乱,不能快速定位到错误的原因,因为,每个组件都可能有操作数据的方法;
18
    increment(state) {
19
      state.count++
20
    },
21
    // 注意: 如果组件想要调用 mutations 中的方法,只能使用 this.$store.commit('方法名')
22
    // 这种 调用 mutations 方法的格式,和 this.$emit('父组件中方法名')
23
    subtract(state, obj) {
24
      // 注意: mutations 的 函数参数列表中,最多支持两个参数,其中,参数1: 是 state 状态; 参数2: 通过 commit 提交过来的参数;
25
      console.log(obj)
26
      state.count -= (obj.c + obj.d)
27
    }
28
  },
29
  getters: {
30
    // 注意:这里的 getters, 只负责 对外提供数据,不负责 修改数据,如果想要修改 state 中的数据,请 去找 mutations
31
    optCount: function (state) {
32
      return '当前最新的count值是:' + state.count
33
    }
34
    // 经过咱们回顾对比,发现 getters 中的方法, 和组件中的过滤器比较类似,因为 过滤器和 getters 都没有修改原数据, 都是把原数据做了一层包装,提供给了 调用者;
35
    // 其次, getters 也和 computed 比较像, 只要 state 中的数据发生变化了,那么,如果 getters 正好也引用了这个数据,那么 就会立即触发 getters 的重新求值;
36
  }
37
})
38
39
// 总结:
40
// 1. state中的数据,不能直接修改,如果想要修改,必须通过 mutations
41
// 2. 如果组件想要直接 从 state 上获取数据: 需要 this.$store.state.***
42
// 3. 如果 组件,想要修改数据,必须使用 mutations 提供的方法,需要通过 this.$store.commit('方法的名称', 唯一的一个参数)
43
// 4. 如果 store 中 state 上的数据, 在对外提供的时候,需要做一层包装,那么 ,推荐使用 getters, 如果需要使用 getters ,则用 this.$store.getters.***
44
45
46
import App from './App.vue'
47
48
const vm = new Vue({
49
  el: '#app',
50
  render: c => c(App),
51
  store // 5. 将 vuex 创建的 store 挂载到 VM 实例上, 只要挂载到了 vm 上,任何组件都能使用 store 来存取数据
52
})
1
<template>
2
  <div>
3
    <input type="button" value="减少" @click="remove">
4
    <input type="button" value="增加" @click="add">
5
    <br>
6
    <input type="text" v-model="$store.state.count">
7
  </div>
8
</template>
9
10
<script>
11
export default {
12
  data() {
13
    return {
14
      // count: 0
15
    };
16
  },
17
  methods: {
18
    add() {
19
      // 千万不要这么用,不符合 vuex 的设计理念
20
      // this.$store.state.count++;
21
      this.$store.commit("increment");
22
    },
23
    remove() {
24
      this.$store.commit("subtract", { c: 3, d: 1 });
25
    }
26
  },
27
  computed:{
28
    fullname: {
29
      get(){},
30
      set(){}
31
    }
32
  }
33
};
34
</script>
35
36
<style lang="scss" scoped>
37
38
</style>
文章作者: Byron
文章链接: https://byronk.top/2019/10/22/vuex%E4%BD%BF%E7%94%A8%E6%B3%A8%E6%84%8F%E7%BB%86%E8%8A%82/
版权声明: 本博客所有文章除特别声明外,均采用 CC BY-NC-SA 4.0 许可协议。转载请注明来自 byron's | BLOG
打赏
  • 微信
  • 支付宝

评论