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

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

  • 相关标签:Vue VueX Action
  • 推荐:PHP从基础到实战教程视频

    • 上一篇:Vue详解之增加组件扩展性的slot
    • 下一篇:聊聊Vue的事件监听指令v-on

    相关文章

    相关视频


    • 聊聊不使用Vuex怎么封装登录状态判断
    • 通俗易懂!详解VUEX状态仓库管理
    • 一文解析VUEX getters计算属性的基本使用
    • Vuex状态管理之Mutation的使用详解
    • Vuex状态管理之Action异步操作详解
    • vuex持久化
    • vues的介绍和使用,通过vuex状态管理
    • 使用vuex实现右上角状态切换-完整流程

    专题推荐

    • 独孤九贱-php全栈开发教程

      全栈 170W+

      主讲:Peter-Zhu 轻松幽默、简短易学,非常适合PHP学习入门

    • 玉女心经-web前端开发教程

      入门 80W+

      主讲:灭绝师太 由浅入深、明快简洁,非常适合前端学习入门

    • 天龙八部-实战开发教程

      实战 120W+

      主讲:西门大官人 思路清晰、严谨规范,适合有一定web编程基础学习

    • Laravel 9 学习正当时—保姆级教程,想学不会都难!

      实战 21317次学习

      主讲:博愿 全栈工程师,拼命探索,不计后果

    • 千万级数据并发解决方案(理论+实战)

      实战 55750次学习

      主讲:西门大官人 思路清晰、严谨规范,适合有一定web编程基础学习

    • 共22门课程,总价3725元,开通VIP会员免费学

      实战 55750次学习

      主讲:Peter-Zhu、西门大官人、灭绝师太、欧阳克

    作者信息

    藏色散人

    好好学习天天向上!

    最近文章
    详解Vue项目如何创建路由页面426
    深析Vue router-link组件实现路由导航390
    超详细!总结vue实现路由跳转的3种方式!728
    ❤️‍🔥IPIDEA 爬虫采集无IP封禁 无限并发1679
    讲师入驻(把你的才变成财)
    IPIDEA,高度匿名的真实住宅代理,爬虫采集无IP封禁,千万IP资源,无限并发,领取2G流量,住宅IP免费用
    ❤️‍🔥IPIDEA,高度匿名的真实住宅代理,爬虫采集无IP封禁,千万IP资源,无限并发,领取2G流量,住宅IP免费用
    • 最新文章
    • 热门排行

    • ❤️‍🔥共22门课程,总价3725元,开通VIP会员免费学习
    • 一文掌握vue-router的安装与使用
    • 深入探讨Vue中数据双向绑定的原理及实现
    • 实例详解Vue中v-model指令的用法
    • 详解Vue项目如何创建路由页面
    • 实例详解vue基于element-plus的组件二次封装
    • 深析Vue router-link组件实现路由导航
    • 详解Vue渲染列表指令:v-for
    • vue引入Element-plus的全局引入与局部引入(附代码)

    • 共22门课程,总价3725元,开通VIP会员免费学习!
    • vue3.0和vue2.0的区别是什么?
    • .vue 是什么
    • vue子组件怎么向父组件传值
    • vue父组件怎么调用子组件的方法
    • vue子组件怎么调用父组件的方法
    • vue-cli-service不是内部或外部命令怎么解决
    • vue中elementUI是什么
    • vue常用指令有哪些
    视频教程分类
    • php视频教程
    • html视频教程
    • css视频教程
    • JS视频教程
    • jQuery视频教程
    • mysql视频教程
    • Linux视频教程
    • Python视频教程

    Comment list 共有 0 条评论

    暂无评论

    微信小程序

    微信扫一扫体验

    立即
    投稿

    微信公众账号

    微信扫一扫加关注

    发表
    评论
    返回
    顶部