Vuex使用、辅助函数

文章详细介绍了Vuex框架中管理状态的三种主要方式:State的访问(通过$store.state或计算属性),Mutation的使用(用于变更Store数据,只能通过commit触发),以及Action的处理(用于异步任务,通过dispatch触发并在内部commitMutation)。每种方式都提供了直接调用和映射为组件方法的两种方法,确保了数据流的控制和可追踪性。
摘要由CSDN通过智能技术生成

1.State

  1. 组件访问State中数据的第一种方式:
this.$store.state.全局数据名称
  1. 第二种方式:
// 1. 从 vuex 中按需导入
import {mapGetters} from "vuex"
export default{
//标签里面直接使用变量
  computed:{
	...mapGetters(["name","age","arr"]),
	//this.name  调用state变量
  }
}

  1. 第三种方式:
// 1. 从 vuex 中按需导入 mapState 函数
import { mapState } from 'vuex'
// 2. 将全局数据,映射为当前组件的计算属性
computed: {
  ...mapState(['count'])
}

2.Mutation

Mutation用于变更Store中的数据

  1. 只能通过mutation变更Store数据,不可以直接操作Store中的数据
  2. 通过这种方法虽然操作繁琐,但是可以集中监控所有数据的变化
 // 定义 Mutation
 const store = new Vuex.Store({
 state: {
   count: 0
 },
 mutations: {
   add(state) {
     // 变更状态
     state.count++
   }
 }
 })
  1. 触发 mutations 的第一种方式
 this.$store.commit('add')
 // 触发 mutations 时携带参数
 this.$store.commit('addN', 3)
  1. 触发mutations 的第二种方式
// 1. 从 vuex 中按需导入 mapMutations 函数
import { mapMutations } from 'vuex'
// 通过刚才导入的 mapMutations 函数,将需要的 mutations 函数,映射为当前组件的 methods 方法:
// 2. 将指定的 mutations 函数,映射为当前组件的 methods 函数
methods: {
 ...mapMutations(['add', 'addN'])
 //this.add() 调用
}

3.Action

Action 用于处理异步任务。
如果通过异步操作变更数据,必须通过 Action,而不能使用 Mutation,但是在 Action 中还是要通过触发Mutation 的方式间接变更数据。

// 定义 Action
 const store = new Vuex.Store({
 // ...省略其他代码
   mutations: {
     addN(state, step) {
       state.count += step
     }
   },
   actions: {
     addNAsync(context, step) {
       setTimeout(() => {
         context.commit('addN', step)
       }, 1000)
     } 
  }
})
  1. 第一种触发方式
 // 触发 Action
 // 在调用 dispatch 函数,
 // 触发 actions 时携带参数
 this.$store.dispatch('addNAsync', 5)
  1. 第二种触发方式
import {mapActions} from "vuex"
export default{
  methods:{
    //this.调用方法
    ...mapActions(["func1","func2"])
    ...mapActions("cate",["reqList"]), //命名空间
    //this.reqList()
    //console.log(this.$store.getters['cate/list'])
  }
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

CongJiYong

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值