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

Vuex actions?異步操作方法詳解

 更新時間:2023年10月02日 09:49:20   投稿:wdc  
這篇文章主要介紹了Vuex actions?異步操作方法,需要的朋友可以參考下

作用:異步操作寫在actions中,自身無法修改state中的數(shù)據(jù),只能提交方法給mutations,通過mutations修改state中的數(shù)據(jù)

  • 需要通過dispatch提交異步
  • actions中接收異步,內(nèi)部有一個參數(shù)context相當于store,可以通過context.commit提交同步
  • mutations中接收同步,在對state中的數(shù)據(jù)進行修改
// state中定義一些初始數(shù)據(jù)用來舉例
state: {
  // 定義一個數(shù)字
  count: 0,
  // 定義一個對象
  coderyg: {
    name: 'coderyg',
    age: 25,
    height: 1.93
  },
  // 定義一個字符串
  info: 'swk'
}

實例1:普通用法(需求:3s后修改info為zbj)

// App.vue
<p>{{ $store.state.info }}</p>  //此時info是swk
<button @click="update">3s后修改info</button>
// dispatch提交異步
update() {
  this.$store.dispatch('aUpdate');
}
// index.js
// actions接收異步
actions: {
  // 這里的context可以當作store,通過context.commit提交同步
  aUpdate(context) {
    setTimeout(() => {
      // 提交同步
      context.commit('mUpdate');
    }, 3000)
  }
},
// mutations接收同步
mutations: {
  mUpdate(state) {
    state.info = 'zbj'
  }
}

實例2.1:直接提交一個大對象攜帶數(shù)據(jù)

// App.vue
<p>{{ $store.state.info }}</p>  //此時info是swk
<button @click="update('zbj')">3s后修改info</button>
// dispatch提交異步
update(info) {
  this.$store.dispatch(這里開始{
    type: 'aUpdate',
    info
  }這里結(jié)束是payload);
}
// index.js
// actions接收異步,傳遞過來的payload作為接收的第二個參數(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;
  }
}

實例2.2普通提交后面攜帶多個參數(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();
  }
}

實例2.3通過Promise優(yōu)雅提交

使用dispatch提交異步時,接收異步請求使用Promise,當在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)用方法測試
        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)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • vue如何動態(tài)設置背景漸變色

    vue如何動態(tài)設置背景漸變色

    這篇文章主要介紹了vue如何動態(tài)設置背景漸變色問題,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2024-08-08
  • Vue監(jiān)聽頁面刷新和關(guān)閉功能

    Vue監(jiān)聽頁面刷新和關(guān)閉功能

    我在做項目的時候,有一個需求,在離開(跳轉(zhuǎn)或者關(guān)閉)購物車頁面或者刷新購物車頁面的時候向服務器提交一次購物車商品數(shù)量的變化。這篇文章主要介紹了vue監(jiān)聽頁面刷新和關(guān)閉功能,需要的朋友可以參考下
    2019-06-06
  • Vue中之nextTick函數(shù)源碼分析詳解

    Vue中之nextTick函數(shù)源碼分析詳解

    這篇文章主要介紹了Vue中之nextTick函數(shù)源碼分析,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2017-10-10
  • vue實現(xiàn)聊天框自動滾動的示例代碼

    vue實現(xiàn)聊天框自動滾動的示例代碼

    本文主要介紹了vue實現(xiàn)聊天框自動滾動的示例代碼,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2023-05-05
  • vite+vue3項目解決低版本兼容性問題解決方案(Safari白屏)

    vite+vue3項目解決低版本兼容性問題解決方案(Safari白屏)

    這篇文章主要介紹了vite+vue3項目解決低版本兼容性問題(Safari白屏),使用官方插件 @vitejs/plugin-legacy 為打包后的文件提供傳統(tǒng)瀏覽器兼容性支持,本文給大家介紹的非常詳細,需要的朋友可以參考下
    2024-03-03
  • Vue中Axios從遠程/后臺讀取數(shù)據(jù)

    Vue中Axios從遠程/后臺讀取數(shù)據(jù)

    今天小編就為大家分享一篇關(guān)于Vue中Axios從遠程/后臺讀取數(shù)據(jù),小編覺得內(nèi)容挺不錯的,現(xiàn)在分享給大家,具有很好的參考價值,需要的朋友一起跟隨小編來看看吧
    2019-01-01
  • Vue金融數(shù)字格式化(并保留小數(shù))數(shù)字滾動效果實現(xiàn)

    Vue金融數(shù)字格式化(并保留小數(shù))數(shù)字滾動效果實現(xiàn)

    這篇文章主要介紹了Vue金融數(shù)字格式化(并保留小數(shù)) 數(shù)字滾動效果,本文通過實例代碼給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2023-04-04
  • vue項目打包后放服務器非根目錄下圖片找不到問題

    vue項目打包后放服務器非根目錄下圖片找不到問題

    這篇文章主要介紹了vue項目打包后放服務器非根目錄下圖片找不到問題,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2023-12-12
  • Vue 實現(xiàn)把表單form數(shù)據(jù) 轉(zhuǎn)化成json格式的數(shù)據(jù)

    Vue 實現(xiàn)把表單form數(shù)據(jù) 轉(zhuǎn)化成json格式的數(shù)據(jù)

    今天小編就為大家分享一篇Vue 實現(xiàn)把表單form數(shù)據(jù) 轉(zhuǎn)化成json格式的數(shù)據(jù),具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2019-10-10
  • Vue中組件的數(shù)據(jù)共享分析講解

    Vue中組件的數(shù)據(jù)共享分析講解

    本文章向大家介紹vue組件中的數(shù)據(jù)共享,主要包括vue組件中的數(shù)據(jù)共享使用實例、應用技巧、基本知識點總結(jié)和需要注意事項,具有一定的參考價值,需要的朋友可以參考一下
    2022-12-12

最新評論