vue学习十一:vuex状态管理模式

为什么要使用vuex:

整站有很多数据和状态,由很多组件拼成,组件间可能要共享一些状态,比如登录、注册部分每个页面都要有,数据要进行同步更新,状态很多的时候,通过事件触发也不切实际,所以出现了状态管理
vuex 是 Vue 配套的 公共数据管理工具,它可以把一些共享的数据,保存到 vuex 中,方便 整个程序中的任何组件直接获取或修改我们的公共数据

props、data和vuex的区别:

Vuex是为了保存组件之间共享数据而诞生的,如果组件之间有要共享的数据,可以直接挂载到vuex中,而不必通过父子组件之间传值了,如果组件的数据不需要共享,此时,这些不需要共享的私有数据,没有必要放到vuex中

只有共享的数据,才有权利放到vuex中

组件内部私有的数据,只要放到组件的data中即可

配置vuex的步骤:

安装vuex:

cnpm i vuex -S

导入包:

import Vuex from 'vuex'

注册vuex到vue中:

Vue.use(Vuex)

new Vuex.Store() 实例,得到一个 数据仓储对象

var store = new Vuex.Store({
  state: {

  },
  mutations: {

  },
  getters: {

  }
})

state:

可以把 state 想象成 组件中的 data ,专门用来存储数据的,如果在 组件中想要访问store 中的数据,只能通过 this.$store.state.*** 来访问

  state: {
    count: 0
  },

mutations:

如果组件要操作 store 中的 state 值,只能通过调用 mutations 提供的方法,才能操作对应的数据,不推荐直接操作 state 中的数据比如this.$store.state.count++,原因是万一多个组件因为操作store中的同一个state值导致了数据的紊乱,直接在组件内操作不能快速定位到错误的原因,因为每个组件都可能有不同的操作数据的方法,所以只能通过调用 mutations 提供的方法来操作 store 中的 state 值

如果组件想要调用 mutations 中的方法,只能使用 this.$store.commit('方法名')

mutations 的 函数参数列表中,最多支持两个参数,其中,参数1: 是 state 状态; 参数2: 通过 commit 提交过来的参数;

  mutations: {
    increment(state) {
      state.count++
    },
    subtract(state, obj) {
      console.log(obj)
      state.count -= (obj.c + obj.d)
    }
  },

getters:

getters只负责 对外提供数据,不负责修改数据,如果想要修改 state 中的数据,要通过mutations

getters 中的方法, 和组件中的过滤器比较类似,因为 过滤器和 getters 都没有修改原数据, 都是把原数据做了一层包装,提供给了 调用者

其次, getters 也和 computed 比较像, 只要 state 中的数据发生变化了,那么,如果 getters 正好也引用了这个数据,那么 就会立即触发 getters 的重新求值;

  getters: {
    optCount: function (state) {
      return '当前最新的count值是:' + state.count
    }
  }

将 vuex 创建的 store 挂载到 VM 实例上, 只要挂载到了 vm 上,任何组件都能使用 store 来存取数据

const vm = new Vue({
  el: '#app',
  render: c => c(App),
  store 
})

在其他组件上面访问store中的数据

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 {
      // count: 0
    };
  },
  methods: {
    add() {
      // 千万不要这么用,不符合 vuex 的设计理念
      // this.$store.state.count++;
      this.$store.commit("increment");
    },
    remove() {
      this.$store.commit("subtract", { c: 3, d: 1 });
    }
  },
  computed:{
    fullname: {
      get(){},
      set(){}
    }
  }
};
</script>

<style lang="scss" scoped>

</style>

amount.vue:

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

<script>
</script>

<style lang="scss" scoped>

</style>

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值