Vuex核心概念Mutations

Mutation 是 Vuex 中用于安全更改 Store 数据的机制。必须通过 commit 方法调用 mutations,不允许直接修改 Store。示例展示了如何定义和触发 mutation,包括传参。同时强调 mutations 应避免执行异步操作。
摘要由CSDN通过智能技术生成

Mutation

Mutation 用于改变Store中的数据。

  1. 只能通过mutation变更Store数据,不可以直接操作Store中的数据。
  2. 通过这种方式虽然操作起来稍微繁琐一些,但是可以集中监控所有数据的变化。
//定义 Mutation
const store = new Vuex.Store({
     state:{
       count:0;
       },
     mutations:{
       add(state){    
       //变更状态
       state.count++
       }
     } 
   })
//触发mutation
methods: {
   handle1(){
   //触发mutations的第一种方式
   //commit 的作用就是调用mutations中的某个函数
   this.$store.commit('add')
   }
  }

可以在触发mutations时传递参数:

const store = new Vuex.Store({
      store:{
      count :0;
      },
      mutations:{
      addN(state,step){
      //变更状态
      state.count += step
      }
     }
    })
   //触发mutation
   methods:{
    handle2 (){
      //在调用commit函数,
      //触发mutations时携带参数
      this.$store.commit('addN',3)
      }
     }

this.$store.commit()是触发mutations的第一种方式,以下是触发mutations的第二种方式:

  //1.从 vuex 中按需导入mapMutations 函数
  import  { mapMutations } from  'vuex'

通过导入的mapMutations函数,将需要的mutations函数,映射为当前组件的methods方法:

 //2、将指定的 mutations 函数,映射为当前组件的methods 函数
 methods:{
      ...mapMutations(['add','addN'])btnHandle1(){
       this.add()
       },
       btnHandle2(){
           this.addN(3)
           }
      }

注意:不要在mutations函数中,执行异步操作,下面是错误写法:

   mutations:{
    add(state){
       setTimeout(()=>{
         state.count++;
       },1000);
      }
  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值