
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如果是从接口获取数据,需要使用异步,否则可能会有问题 


网友评论文明上网理性发言 已有0人参与
发表评论: