Vuex的简单使用

2022-09-24 09:13:32 浏览数 (1)

一、简介

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

简而言之,Vuex采用类似全局对象的形式来管理所有组件的公用数据,如果想修改这个全局对象的数据,得按照Vuex提供的方式来修改(不能自己随意用自己的方式来修改)。

二、优点

是vue组件相互传递数据的重要工具 Vuex状态管理跟使用传统全局变量的不同之处: 1.Vuex的状态存储是响应式的:就是当你的组件使用到了这个Vuex 的状态,一旦它改变了,所有关联的组件都会自动更新相对应的数 据,这样开发者省事很多。 . 2.不能直接修改Vuex的状态:如果是个全局对象变量,要修改很容 易,但是在Vuex中不能这样做,想修改就得使用Vuex提供的唯一途 径:显示地提交(commint)mutations来实现修改。这样做的好处 就是方便我们跟踪,每一个状态的变化,在开发过程中调试的时候, 非常实用。

三、使用步骤

  1. 安装Vuex npm install vuex --save
  2. 引用Vuex(新建一个js文件 store.js)
代码语言:javascript复制
<code class="language-vue line-numbers">import Vue from 'vue'
import Vuex from 'vuex'
Vue.use(Vuex)
  1. 创建仓库Store
代码语言:javascript复制
var store = new Vuex.Store({
    // 可以把 state 想象成 组件中的 data ,专门用来存储数据的
    // 如果在 组件中,想要访问,store 中的数据,只能通过 this.$store.state.*** 来访问
    state: {
        count: 1,
        a: 5
    },
     // 注意: 如果要操作 store 中的 state 值,只能通过 调用 mutations 提供的方法,才能操作对应的数据,不推荐直接操作 state 中的数据,因为 万一导致了数据的紊乱,不能快速定位到错误的原因,因为,每个组件都可能有操作数据的方法;
    mutations: {
        add(state, payload) {
            state.count  ;
        },
        sub(state) {
            state.count--;
        }
    },
    //用来解决异步流程来改变state数据。而matution是直接进行同步操作的,如果你在mutations里进行异步操作,你会发现没用,并不会起任何效果只有通过action=>mutations=>states,这个流程进行操作
    actions: {
        add({
            commit
        }, payload) {
            commit('add', payload);
        },
        sub({
            commit
        }, payload) {
            commit('sub', payload);
        }
    },
    // 经过咱们回顾对比,发现 getters 中的方法, 和组件中的过滤器比较类似,因为 过滤器和 getters 都没有修改原数据, 都是把原数据做了一层包装,提供给了 调用者;
    // 其次, getters 也和 computed 比较像, 只要 state 中的数据发生变化了,那么,如果 getters 正好也引用了这个数据,那么 就会立即触发 getters 的重新求值;
    getters: {
        // 注意:这里的 getters, 只负责 对外提供数据,不负责 修改数据,如果想要修改 state 中的数据,请 去找 mutations
        obj: function (state) {
            return "包装后的结果:"   state.count;
        }
    }
})
  1. 导出仓库store
代码语言:javascript复制
export default {
    store
}
  1. 挂载仓库store
代码语言:javascript复制
new Vue({
  router,
    //必须使用展开运算符,因为导出的是一个object对象,是es6语法
  ...store,
  render: h => h(App)
}).$mount('#app')

总结

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

使用store仓库

具体如下,在一个组件中使用

代码语言:javascript复制
<template>
  <div class="hello">
    <h2>{{ msg }}</h2>
    <h3>我是从vuex中获取的:-------{{$store.state.count}}      {{$store.state.a}}</h3>
    <h3>{{$store.getters.obj}}</h3>
    <button @click="add(100)">增加</button>
    <button @click="sub">减少</button>
  </div>
</template>

<script>
//固定写法:mapActions是一个辅助函数,用于获取vuex仓库里的对象
import { mapActions } from "vuex";
export default {
  name: "HelloWorld",
  props: {
    msg: String
  },
  methods: {
    //必须使用展开运算符
    ...mapActions(["add", "sub"])
  }
};
</script>
<style scoped lang="less">
</style>

效果如下

0 人点赞