• 技术文章 >web前端 >Vue.js

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

    藏色散人藏色散人2022-08-10 15:30:01转载1697

    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异步操作详解的详细内容,更多请关注php中文网其它相关文章!

    声明:本文转载于:cnblogs,如有侵犯,请联系admin@php.cn删除

    前端(VUE)零基础到就业课程:点击学习

    清晰的学习路线+老师随时辅导答疑

    快捷开发Web应用及小程序:点击使用

    支持亿级表,高并发,自动生成可视化后台。

    专题推荐:Vue VueX Action
    上一篇:Vue详解之增加组件扩展性的slot 下一篇:自己动手写 PHP MVC 框架(40节精讲/巨细/新人进阶必看)

    相关文章推荐

    • ❤️‍🔥共22门课程,总价3725元,会员免费学• ❤️‍🔥接口自动化测试不想写代码?• 聊聊不使用Vuex怎么封装登录状态判断• 通俗易懂!详解VUEX状态仓库管理• 一文解析VUEX getters计算属性的基本使用• Vuex状态管理之Mutation的使用详解
    1/1

    PHP中文网