Vuex actions?異步操作方法詳解
作用:異步操作寫在actions中,自身無法修改state中的數(shù)據(jù),只能提交方法給mutations,通過mutations修改state中的數(shù)據(jù)
- 需要通過dispatch提交異步
- actions中接收異步,內(nèi)部有一個(gè)參數(shù)context相當(dāng)于store,可以通過context.commit提交同步
- mutations中接收同步,在對(duì)state中的數(shù)據(jù)進(jìn)行修改
// state中定義一些初始數(shù)據(jù)用來舉例 state: { // 定義一個(gè)數(shù)字 count: 0, // 定義一個(gè)對(duì)象 coderyg: { name: 'coderyg', age: 25, height: 1.93 }, // 定義一個(gè)字符串 info: 'swk' }
實(shí)例1:普通用法(需求:3s后修改info為zbj)
// App.vue <p>{{ $store.state.info }}</p> //此時(shí)info是swk <button @click="update">3s后修改info</button> // dispatch提交異步 update() { this.$store.dispatch('aUpdate'); } // index.js // actions接收異步 actions: { // 這里的context可以當(dāng)作store,通過context.commit提交同步 aUpdate(context) { setTimeout(() => { // 提交同步 context.commit('mUpdate'); }, 3000) } }, // mutations接收同步 mutations: { mUpdate(state) { state.info = 'zbj' } }
實(shí)例2.1:直接提交一個(gè)大對(duì)象攜帶數(shù)據(jù)
// App.vue <p>{{ $store.state.info }}</p> //此時(shí)info是swk <button @click="update('zbj')">3s后修改info</button> // dispatch提交異步 update(info) { this.$store.dispatch(這里開始{ type: 'aUpdate', info }這里結(jié)束是payload); } // index.js // actions接收異步,傳遞過來的payload作為接收的第二個(gè)參數(shù) actions: { aUpdate(context, payload) { setTimeout(() => { // context.commit提交同步 context.commit('mUpdate', payload); console.log(payload); }, 3000) } } // mutations接收同步 mutations: { mUpdate(state, payload) { state.info = payload.info; } }
實(shí)例2.2普通提交后面攜帶多個(gè)參數(shù)
// App.vue update() { // 提交異步 this.$store.dispatch('aUpdate', 從這開始{ message: 'hello vuejs', success: () => { console.log('提交成功'); } }到這結(jié)束是payload) } // index.js actions: { // 接收異步 aUpdate(context, payload) { setTimeout(() => { // 提交同步 context.commit('mUpdate', payload); }, 3000) } }, mutations: { // 接收同步 mUpdate(state, payload) { // 修改數(shù)據(jù) state.info = payload.message; // 調(diào)用方法 payload.success(); } }
實(shí)例2.3通過Promise優(yōu)雅提交
使用dispatch提交異步時(shí),接收異步請(qǐng)求使用Promise,當(dāng)在Promise內(nèi)部調(diào)用resolve()方法,則可以在dispatch后跟上then()方法
// App.vue update() { // 提交異步 this.$store .dispatch('aUpdate', 從這開始{ message: 'hello vuejs', success: () => { console.log('success'); } }到這結(jié)束是payload) // 這里調(diào)用.then .then(res => console.log(res)) } // index.js actions: { // 接收異步 aUpdate(context, payload) { // 直接return Promise return new Promise((resolve, reject) => { setTimeout(() => { // 提交同步 context.commit('mUpdate', payload); // 調(diào)用方法測(cè)試 payload.success(); // 調(diào)用resolve resolve('res'); }, 3000) }); } }, mutations: { // 接收同步 mUpdate(state, payload) { state.info = payload.message; } }
到此這篇關(guān)于Vuex actions:異步操作詳解的文章就介紹到這了,更多相關(guān)Vuex actions:異步操作詳解內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
vue如何動(dòng)態(tài)設(shè)置背景漸變色
這篇文章主要介紹了vue如何動(dòng)態(tài)設(shè)置背景漸變色問題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2024-08-08vue實(shí)現(xiàn)聊天框自動(dòng)滾動(dòng)的示例代碼
本文主要介紹了vue實(shí)現(xiàn)聊天框自動(dòng)滾動(dòng)的示例代碼,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2023-05-05vite+vue3項(xiàng)目解決低版本兼容性問題解決方案(Safari白屏)
這篇文章主要介紹了vite+vue3項(xiàng)目解決低版本兼容性問題(Safari白屏),使用官方插件 @vitejs/plugin-legacy 為打包后的文件提供傳統(tǒng)瀏覽器兼容性支持,本文給大家介紹的非常詳細(xì),需要的朋友可以參考下2024-03-03Vue中Axios從遠(yuǎn)程/后臺(tái)讀取數(shù)據(jù)
今天小編就為大家分享一篇關(guān)于Vue中Axios從遠(yuǎn)程/后臺(tái)讀取數(shù)據(jù),小編覺得內(nèi)容挺不錯(cuò)的,現(xiàn)在分享給大家,具有很好的參考價(jià)值,需要的朋友一起跟隨小編來看看吧2019-01-01Vue金融數(shù)字格式化(并保留小數(shù))數(shù)字滾動(dòng)效果實(shí)現(xiàn)
這篇文章主要介紹了Vue金融數(shù)字格式化(并保留小數(shù)) 數(shù)字滾動(dòng)效果,本文通過實(shí)例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2023-04-04vue項(xiàng)目打包后放服務(wù)器非根目錄下圖片找不到問題
這篇文章主要介紹了vue項(xiàng)目打包后放服務(wù)器非根目錄下圖片找不到問題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-12-12Vue 實(shí)現(xiàn)把表單form數(shù)據(jù) 轉(zhuǎn)化成json格式的數(shù)據(jù)
今天小編就為大家分享一篇Vue 實(shí)現(xiàn)把表單form數(shù)據(jù) 轉(zhuǎn)化成json格式的數(shù)據(jù),具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧2019-10-10