亚洲在线久爱草,狠狠天天香蕉网,天天搞日日干久草,伊人亚洲日本欧美

為了賬號安全,請及時綁定郵箱和手機立即綁定

vuex中mutations與actions的使用及區別

標簽:
Vue.js

之前写过简单的vuex应用方法,现在写一下vuex中的   actions 和  mutations 的区别

https://img1.sycdn.imooc.com//5b9734300001a53901700135.jpg

Mutations

mutations 必须是同步函数,为什么?

  举个例子:  官方案例 

mutations: {  someMutation (state) {
    api.callAsyncMethod(() => {
      state.count++    })  }}
我们都知道任何回调函数中进行的状态改变都是无法追踪的,  devtools会对mutations的每一条提交做记录,记录上一次提交之前和提交之后的状态,在上面的例子中无法实现捕捉状态,因为在执行mutations时,内部回调函数还没有执行,
所以此时无法捕捉状态.
再简单来讲,就像大家都吃过核桃,核桃刚产下来的时候是带一层绿色的皮的,我们需要将绿色烧掉,弄掉了,才是我们在市场上见到的只有外面硬壳的核桃,如果我们只剥去绿皮,是不能直接吃的,因为还有一层壳胡着呢.

Actions
vuex肯定不甘示弱,为了解决mutations只有同步的问题,提出了actions(异步),专门用来解决mutations只有同步无异步的问题.
1. 首先先了解一下actions,第一篇vuex中已经讲解了vuex中mutations的用法(https://www.cnblogs.com/0915ty/p/9330439.html),在这里再介绍一下
  (1).MUTATIONS
  const state = {
    xxx: null
  },
  const mutations = {
    [setState](state, value) {
      state.xxx = value
    }
  }
  此处value可以是对象,可以是值等
  组件调用方式: this.$store.commit('setState', [value])

  (2).ACTIONS
  // 第一种写法简写形式
  const actions = {
    [addPlus]({commit}) { // 简写方式,待研究
      commit('[setState]', value)
      //此处value可以是对象,可以是固定值等
    }
  }
  // 第二种形式
  const actions = {
    [addPlus](context) {
      //context 官方给出的指定对象, 此处context可以理解为store对象
      context.commit('[setState]', value)
    }
  }
  /* 两处的commit都是提交的mutations中的字符串的事件类型名称,对应会调用mutations中的回调函数 */
  actions在组件中的调用方式:
  import mapActions from 'vuex'
  methods: {
    ...mapActions: ([
     'addPlus' 
    ]),
    setAddPlus () {
      this.$store.dispatch('addPlus', [value]) // 异步调用mutations
    }
  }
  
简单说到这里,先会用在研究原理



再接再厉,继续努力!!!!!
原文出处:https://www.cnblogs.com/0915ty/p/9626240.html


點擊查看更多內容
TA 點贊

若覺得本文不錯,就分享一下吧!

評論

作者其他優質文章

正在加載中
  • 推薦
  • 評論
  • 收藏
  • 共同學習,寫下你的評論
感謝您的支持,我會繼續努力的~
掃碼打賞,你說多少就多少
贊賞金額會直接到老師賬戶
支付方式
打開微信掃一掃,即可進行掃碼打賞哦
今天注冊有機會得

100積分直接送

付費專欄免費學

大額優惠券免費領

立即參與 放棄機會
微信客服

購課補貼
聯系客服咨詢優惠詳情

幫助反饋 APP下載

慕課網APP
您的移動學習伙伴

公眾號

掃描二維碼
關注慕課網微信公眾號

舉報

0/150
提交
取消