Action 類似于 mutation,不同在于:
Action 提交的是 mutation,而不是直接變更狀態(tài). Action 是異步的,mutation是同步的。
沿用vuex學(xué)習(xí)---簡介的案例:這里是加10 減1
1.在store.js 中 代碼為:
import Vue from 'vue' import Vuex from 'vuex' //使用vuex模塊 Vue.use(Vuex); //聲明靜態(tài)常量為4 const state = { count : 4 }; const mutations = { add(state,n){ state.count +=n.a; }, sub(state){ state.count--; } }; const actions = { //2種書寫方式 addplus(context){ //可以理解為代表了整個的context context.commit('add',{a:10}) }, subplus({commit}){ commit('sub'); } }; //導(dǎo)出一個模塊 export default new Vuex.Store({ state, mutations, actions })
2.在App.vue中 代碼如下:
<template> <div id="app"> <div id="appaaa"> <h1>這是vuex的示例</h1> <p>組件內(nèi)部count{{count}}</p> <p> <button @click = "addplus">+</button> <button @click = "subplus">-</button> </p> </p> </div> </div> </template> <script> //引入mapGetters import {mapState,mapMutations,mapGetters,mapActions} from 'vuex' export default { name:'app', data(){ return { } }, computed:{ ...mapState([ "count" ]), }, methods:{ ...mapActions([ "addplus", "subplus" ]) } } </script> <style> </style>
聲明:本網(wǎng)頁內(nèi)容旨在傳播知識,若有侵權(quán)等問題請及時與本網(wǎng)聯(lián)系,我們將在第一時間刪除處理。TEL:177 7030 7066 E-MAIL:11247931@qq.com