VUE项目mapState和mapActions的作用和用法是什么
Admin 2022-11-02 群英技术资讯 1280 次浏览
在实际应用中,我们有时候会遇到“VUE项目mapState和mapActions的作用和用法是什么”这样的问题,我们该怎样来处理呢?下文给大家介绍了解决方法,希望这篇“VUE项目mapState和mapActions的作用和用法是什么”文章能帮助大家解决问题。最近在开发一套系统,前端使用VUE开发,由于本人是后端开发,前端也会一点,但是VUE接触不多,在VUE项目开发遇到的一些坑记录一下,不是专业前端写好的不好,大家不要唝。。。
在VUE项目中经常会用到mapState和mapActions,mapState主要用于同步全局的变量或者对象,mapActions主要是用于同步定义的方法,一般两者是结合使用,mapState同步项目中定义的全局的变量或者对象,mapActions是用于变量或者对象为空时,调用方法定义的全局方法获取。
mapActions和mapState需要引用vuex,所以在页面里面需要 使用下面的代码引入
import { mapActions, mapState } from 'vuex'
由于全局数据需要保存到本地缓存中,所以需要在main.js中引用store,并且定义全局的对象或者变量代码如下
import store from './store'
const state = {
userName,
token,
refreshToken,
tokenExpire,
menus: []
}
Vue.use(Vuex)
export default new Vuex.Store({
state,
actions, // 自定义的一些方法
mutations // 自定义的修改状态的方法
})
如果需要在某个页面获取menus的对象,就可以使用 mapState,如果menus对象已有值就获取直接同步过来
import { mapActions, mapState } from 'vuex'
computed: {
...mapState([
'menus'
])
// 如果要使用menus对象,直接使用this.menus即可
如果menus没有值就需要使用mapActions,将方法同步过来,在页面里面判断menus是否为空,如果为空,调用action获取并且保存,其他页面就可以直接获取了
import { mapActions, mapState } from 'vuex'
methods: {
...mapActions([
'getMenus'
])
if (menus.length === 0)
this.getMenus() // 调用方法获取,这里getMenus如果是从接口获取数据,需要使用异步,否则可能会有问题
根据自己的理解写的,记录一下,如果有什么不正确的地方,欢迎更正。
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:mmqy2019@163.com进行举报,并提供相关证据,查实之后,将立刻删除涉嫌侵权内容。
猜你喜欢
这篇文章主要为大家介绍了Vue编程三部曲之模型树优化示例详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
这篇文章主要介绍了Vue3内置组件Teleport使用方法,Teleport是Vue 3.0 新增的一个内置组件,主要是为了解决一些特殊场景下模态对话框组件、组件的渲染,带着些许的了解一起走进下面文章的详细内容吧
这篇文章给大家分享的是react实现循环数据和循环列表的代码。小编觉得挺实用的,因此分享给大家做个参考,感兴趣的朋友接一起跟随小编看看吧。
jQuery中清除兄弟元素的方法是什么?在jQuery中,我们想要清楚兄弟元素,可以使用到remove()方法,文中的示例代码介绍得很详细,有需要的朋友可以参考,接下来就跟随小编一起了解看看吧。
今天给大家分享的是使用JavaScript实现简易的alert弹框功能的内容,实现效果及代码如下,对新手学习JavaScript有一定的帮助,需要的朋友可以参考,希望大家阅读完这篇文章能有所收获,接下来我们就一起来了解看看吧。
成为群英会员,开启智能安全云计算之旅
立即注册关注或联系群英网络
7x24小时售前:400-678-4567
7x24小时售后:0668-2555666
24小时QQ客服
群英微信公众号
CNNIC域名投诉举报处理平台
服务电话:010-58813000
服务邮箱:service@cnnic.cn
投诉与建议:0668-2555555
Copyright © QY Network Company Ltd. All Rights Reserved. 2003-2020 群英 版权所有
增值电信经营许可证 : B1.B2-20140078 ICP核准(ICP备案)粤ICP备09006778号 域名注册商资质 粤 D3.1-20240008