欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

vuex actions異步修改狀態(tài)的實例詳解

 更新時間:2019年11月06日 10:19:41   作者:周行知  
今天小編就為大家分享一篇vuex actions異步修改狀態(tài)的實例詳解,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧

actions異步修改狀態(tài)與mutations同步修改狀態(tài)是兩個容易混淆的概念,因為兩者在執(zhí)行上,很難測試出兩者的差別,而我們要區(qū)別它們兩,首先你得區(qū)分同步與異步,我的理解是,同步更像是一條流水線作業(yè),而異步則更像是多條,例子你比如打電話,我們通常是我打給我媽,打完之后,再跟我爸打,而異步更像是某聊天工具,你既可以跟你爸聊,又可以跟你媽聊,你跟你媽聊可以在你爸的后面,也可以在他前面,你爸也是

而actions與mutations的區(qū)別就在此,mutations是你進行用百度錢包買一件商品時,你必須先把東西購買流程走完你才能再購買另一件商品而actions是你完全可以一樣在準備結(jié)算時,你可以選擇其他商品,結(jié)算完其他商品再進行商品的結(jié)算,也可以一起結(jié)算。

下面我具體介紹actions寫法

第一步 在你建立vuex的store.js中聲明actions方法

import Vue from 'vue'
import Vuex from 'vuex'
Vue.use(Vuex)
const state={//狀態(tài)對象
 
count1:1,
 
 
 
},
const mutations={//觸發(fā)狀態(tài)
 jia(state,n){
    state.count1+=n;
  },
 jian(state){
    state.count1--;
  },
 
},
const actions={
jiaAction(context){
 
context.commit('jia',10)
/*這句話就是說,我現(xiàn)在store調(diào)用了同步的方法jia()*/
 
},
jianAction({commit}){
 
 
commit('jian')/*這句話就是說,我現(xiàn)在store調(diào)用了同步的方法jian()*/
}
 
 
}
 
 
export default new Vuex.Store({
 
 
 
state,
mutations,
getters,
actions/*這與state,mutations的操作方法是相同*/
})

第二步 在你的模板(比如a.vue)里引入你需要actions方法

1)import引入mapActions

import {mapState,mapMutations,mapGetters,mapActions} from 'vuex'

2)在你的方法中引入 ...mapActions(['jiaAction','jianAction'])

格式一般都是固定照抄即可

代碼如下:

<template>
<div>
 
<div>
 
{{count1}}
 
</div>
 
</div>
</template>
<script>
  import store from '@/store'
  import {mapState,mapMutations,mapGetters,mapActions} from 'vuex'
  export default{
    data(){
      return{
       
      }
    },
  
 methods:{
  ...mapMutations([ 
    'jia','jian'
  ]),
  ...mapActions(['jiaAction','jianAction'])
}, 
 
   computed:{
   
   
   ...mapState(["count1"]),
 
 
   },
    
    store
    
  }
</script>
 
 
 
 
 
<style scoped>
.color{
color:red;
}
 
</style>

第三步在你的組件的模板(a.vue)里引入點擊事件

代碼如下:

<template>
<div>
 
<div>
 
{{count1}}
 
 
</div>
<p>
 <button @click="jiaAction">+</button>
 <button @click="jianAction">-</button>
</p>
</div>
</template>

整體代碼如下:

<template>
<div>
 
<div>
 
{{count1}}
 
</div>
<p>
 <button @click="jiaAction">+</button>
 <button @click="jianAction">-</button>
</p>
</div>
</template>
<script>
  import store from '@/store'
  import {mapState,mapMutations,mapGetters,mapActions} from 'vuex'
  export default{
    data(){
      return{
       
      }
    },
  
 methods:{
  ...mapMutations([ 
    'jia','jian'
  ]),
  ...mapActions(['jiaAction','jianAction'])
}, 
 
   computed:{
   
   
   ...mapState(["count1"]),
 
 
   },
    
    store
    
  }
</script>

注:現(xiàn)在你點擊你的+或-的按鈕,觀察它的值與你把

<button @click="jiaAction">+</button>
 <button @click="jianAction">-</button>

換成

<button @click="jia">+</button>
 <button @click="jian">-</button>

有何不同?

沒有區(qū)別說明你調(diào)試代碼成功

第四步 進行異步驗證

我們在我們的store.js中的jiaAction加入jiaAction方法

setTimeout(()=>{
context.commit('jian')
},3000)
console.log('我先被執(zhí)行');

你再觀察結(jié)果,你會發(fā)現(xiàn)jian這個方法在3s之后執(zhí)行,你點jia依然可以在3s之內(nèi)先執(zhí)行,這就是異步修改狀態(tài)與同步的區(qū)別。

整體代碼如下:

a.vue部分

<template>
<div>
 
<div>
 
{{count1}}
 
 
</div>
<p>
 <button @click="jiaAction">+</button>
 <button @click="jianAction">-</button>
</p>
</div>
</template>

整體代碼如下:

<template>
<div>
 
<div>
 
{{count1}}
 
</div>
<p>
 <button @click="jiaAction">+</button>
 <button @click="jianAction">-</button>
</p>
</div>
</template>
<script>
  import store from '@/store'
  import {mapState,mapMutations,mapGetters,mapActions} from 'vuex'
  export default{
    data(){
      return{
       
      }
    },
  
 methods:{
  ...mapMutations([ 
    'jia','jian'
  ]),
  ...mapActions(['jiaAction','jianAction'])
}, 
 
   computed:{
   
   
   ...mapState(["count1"]),
 
 
   },
    
    store
    
  }
</script>
 

store.js部分

import Vue from 'vue'
import Vuex from 'vuex'
Vue.use(Vuex)
const state={//狀態(tài)對象

count1:1,



},
const mutations={//觸發(fā)狀態(tài)
 jia(state,n){
    state.count1+=n;
  },
jian(state){
    state.count1--;
  },

},
const actions={
jiaAction(context){
setTimeout(()=>{
context.commit('jian')
},3000)
console.log('我先被執(zhí)行');
context.commit('jia',10)
/*這句話就是說,我現(xiàn)在store調(diào)用了同步的方法jia()*/

},
jianAction({commit}){


commit('jian')/*這句話就是說,我現(xiàn)在store調(diào)用了同步的方法jian()*/
}


}


export default new Vuex.Store({



state,
mutations,
getters,
actions/*這與state,mutations的操作方法是相同*/
})

以上這篇vuex actions異步修改狀態(tài)的實例詳解就是小編分享給大家的全部內(nèi)容了,希望能給大家一個參考,也希望大家多多支持腳本之家。

相關(guān)文章

  • Vue3.2.x中的小技巧及注意事項總結(jié)

    Vue3.2.x中的小技巧及注意事項總結(jié)

    Vue是一套用于構(gòu)建用戶界面的漸進式JavaScript框架,是目前最火的前端框架之一,是前端工程師的必備技能,下面這篇文章主要給大家介紹了關(guān)于Vue3.2.x中的小技巧及注意事項的相關(guān)資料,需要的朋友可以參考下
    2022-04-04
  • Vue實現(xiàn)簡易計算器

    Vue實現(xiàn)簡易計算器

    這篇文章主要為大家詳細介紹了用Vue制作的簡易計算器,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2020-02-02
  • Vue.js實現(xiàn)輸入框綁定的實例代碼

    Vue.js實現(xiàn)輸入框綁定的實例代碼

    這篇文章主要介紹了Vue.js實現(xiàn)輸入框綁定的實例代碼,需要的朋友可以參考下
    2017-08-08
  • Vue基于localStorage存儲信息代碼實例

    Vue基于localStorage存儲信息代碼實例

    這篇文章主要介紹了Vue基于localStorage存儲信息代碼實例,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友可以參考下
    2020-11-11
  • Vue實現(xiàn)日歷小插件

    Vue實現(xiàn)日歷小插件

    這篇文章主要為大家詳細介紹了Vue實現(xiàn)日歷小插件,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2019-06-06
  • ant design vue動態(tài)循環(huán)生成表單以及自定義校驗規(guī)則詳解

    ant design vue動態(tài)循環(huán)生成表單以及自定義校驗規(guī)則詳解

    這篇文章主要介紹了ant design vue動態(tài)循環(huán)生成表單以及自定義校驗規(guī)則詳解,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2024-01-01
  • Vue 列表上下過渡效果的實例代碼

    Vue 列表上下過渡效果的實例代碼

    最近有個需求,一個列表上下移動要有簡單過渡效果。本文通過實例代碼給大家介紹Vue 列表上下過渡效果,需要的朋友可以參考下
    2019-06-06
  • Vue2.0基于vue-cli+webpack同級組件之間的通信教程(推薦)

    Vue2.0基于vue-cli+webpack同級組件之間的通信教程(推薦)

    下面小編就為大家?guī)硪黄猇ue2.0基于vue-cli+webpack同級組件之間的通信教程(推薦)。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2017-09-09
  • 詳解在vue3中使用jsx的配置以及一些小問題

    詳解在vue3中使用jsx的配置以及一些小問題

    本文主要介紹了在vue3中使用jsx的配置以及一些小問題,文中通過示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2022-03-03
  • vue如何把字符串中的所有@內(nèi)容,替換成帶標簽的

    vue如何把字符串中的所有@內(nèi)容,替換成帶標簽的

    這篇文章主要介紹了vue如何把字符串中的所有@內(nèi)容,替換成帶標簽的問題,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2023-10-10

最新評論