Vuex状态管理之Action异步操作详解

广告:宝塔Linux面板高效运维的服务器管理软件 点击【 https://www.bt.cn/p/uNLv1L 】立即购买

Vuex状态管理之Action异步操作详解

action用法

一、 基本知识

1、不要再Mutation中进行异步操作.

但是某些情况, 我们确实希望在Vuex中进行一些异步操作, 比如网络请求, 必然是异步的. 这个时候怎么处理呢?

Action类似于Mutation, 但是是用来代替Mutation进行异步操作的.

Action的基本使用代码如下:

【相关推荐:vue.js视频教程】

context是什么?

(1)context是和store对象具有相同方法和属性的对象.

(2)也就是说, 我们可以通过context去进行commit相关的操作, 也可以获取context.state等.

2、action的方法调用

在Vue组件中, 如果我们调用action中的方法, 那么就需要使用dispatch

同样的, 也是支持传递payload

3、Action与Promise

在Action中, 我们可以将异步操作放在一个Promise中, 并且在成功或者失败后, 调用对应的resolve或reject

二、 效果

页面中调用action中的方法

三、目录结构

四、源码

index.js

import { createStore} from 'vuex'export default createStore({state: {counter: 0,info: {  name: 'kobe',  age: 40,  height: 1.98}},mutations: {updateInfo(state) {  state.info.name = 'coderwhy'}},actions: {aUpdateInfo(context, payload) {  return new Promise((resolve, reject) => {    setTimeout(() => {      context.commit('updateInfo');      console.log(payload);      resolve('1111111')    }, 1000)  })}},getters: { },modules: {}})
登录后复制

App.vue

<template>    <div >        <h2>----------action: info对象的内容是否是响应式----------</h2>        <h2>{{$store.state.info}}</h2>        <button @click="updateInfo">修改信息</button>    </div></template> <script>    import {    computed } from 'vue'    import {    useStore } from 'vuex'    export default {        components: {        },        methods: {            updateInfo() {              this.$store.dispatch('aUpdateInfo', '我是携带的信息')                .then(res => {                  console.log('里面完成了提交');                  console.log(res);                })            },                      },        setup() {            return {                              }        }    }</script>
登录后复制

以上就是Vuex状态管理之Action异步操作详解的详细内容,更多请关注9543建站博客其它相关文章!

广告:SSL证书一年128.66元起,点击购买~~~

9543建站博客
一个专注于网站开发、微信开发的技术类纯净博客。

作者头像
admin创始人

肥猫,知名SEO博客站长,14年SEO经验。

上一篇:uniapp如何封装请求路径
下一篇:laravel框架多久可以学会

发表评论

关闭广告
关闭广告