Action 類似于 mutation,不同在于:
Action 提交的是 mutation,而不是直接變更狀態. Action 是異步的,mutation是同步的。
沿用vuex學習---簡介的案例:這里是加10 減1
1.在store.js 中 代碼為:
import Vue from 'vue' import Vuex from 'vuex' //使用vuex模塊 Vue.use(Vuex); //聲明靜態常量為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'); } }; //導出一個模塊 export default new Vuex.Store({ state, mutations, actions })
2.在App.vue中 代碼如下:
<template> <div id="app"> <div id="appaaa"> <h1>這是vuex的示例</h1> <p>組件內部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>
聲明:本網頁內容旨在傳播知識,若有侵權等問題請及時與本網聯系,我們將在第一時間刪除處理。TEL:177 7030 7066 E-MAIL:11247931@qq.com