<em>Mac</em>Book项目 2009年学校开始实施<em>Mac</em>Book项目,所有师生配备一本<em>Mac</em>Book,并同步更新了校园无线网络。学校每周进行电脑技术更新,每月发送技术支持资料,极大改变了教学及学习方式。因此2011
2021-06-01 09:32:01
npm install --save vuex
store和在new Vue中宣告store
import store from './store' store,
在page檔案下建立一個module的js檔案(內容如下)
const state = { HomeStatus:{ LoginStatus:false }, Users:[], } const mutations = { ['setuseinfo'] (state, data) { }, } const actions = { }
在store檔案下建立一個index的js檔案
import Vue from 'vue' import Vuex from 'vuex' import page from '../page/module' Vue.use(Vuex) export default new Vuex.Store({ state: {}, modules:{ page } })
state
:儲存狀態。也就是變數;getters
:派生狀態。也就是set、get中的get,有兩個可選引數:state、getters分別可以獲取state中的變數和其他的getters。外部呼叫方式:store.getters.personInfo()。就和vue的computed差不多;mutations
:提交狀態修改。也就是set、get中的set,這是vuex中唯一修改state的方式,但不支援非同步操作。第一個引數預設是state。外部呼叫方式:store.commit(‘SET_AGE’, 18)。和vue中的methods類似。actions
:和mutations類似。不過actions支援非同步操作。第一個引數預設是和store具有相同引數屬性的物件。外部呼叫方式:store.dispatch(‘nameAsyn’)。this.$store.dispatch(‘user/login’, this.loginForm)modules
:store的子模組,內容就相當於是store的一個範例。呼叫方式和前面介紹的相似,只是要加上當前子模組名,如:store.a.getters.xxx()。import Vue from 'vue' import Vuex from 'vuex' import state from './state.js' import getters from './getters' import mutations from './mutations.js' import actions from './actions.js' //安裝Vue Devtools偵錯工具https://blog.csdn.net/li22356/article/details/113092495 //掛載Vuex,幫助手冊https://www.jianshu.com/p/2e5973fe1223 //模組化可參考https://www.jb51.net/article/150752.htm Vue.use(Vuex); //建立VueX物件,單頁面使用<h1>{{ $store.state.name }}</h1>console.log(this.$store.state.name) //新增state物件Vue.set(state,"age",15),刪除Vue.delete(state,'age') const store = new Vuex.Store({ //存放資料,存放狀態 //使用方法 state, //加工state成員給外界 //state 當前VueX物件中的狀態物件 // getters 當前getters物件,用於將getters下的其他getter拿來用 //元件使用this.$store.getters.fullInfo getters, //state成員操作,操作state資料的方法的集合,比如對該資料的修改、增加、刪除等等。 //元件呼叫this.$store.commit('SET_TOKEN','new token')掛載方法 //同步處理 mutations, //非同步處理 //元件中使用this.$store.dispatch('aEdit','new TOKEN') actions }); export default () => { return store }
import Vue from 'vue' import Vuex from 'vuex' Vue.use(Vuex) export default new Vuex.Store({ //這裡放全域性引數,比如使用者登入資訊 state: { token: "helloVueX", name: "", age: "" }, mutations: { //這裡是set方法,比如對該資料的修改、增加、刪除等等。 //元件呼叫this.$store.commit('SET_TOKEN','new token')掛載方法 SET_TOKEN: (state, token) => { state.token = token console.log(state.token); } }, //getters 當前getters物件(可對物件進行二次更改),用於將getters下的其他getter拿來用,元件通過this.$store.getters.fullInfo拿來使用 getters: { token: state => state.token, nameInfo(state) { return "姓名:" + state.name }, fullInfo(state, getters) { return getters.nameInfo + '年齡:' + state.age } }, //非同步處理 //元件中使用this.$store.dispatch('aEdit','new TOKEN') actions: { QQlogin({commit}, token) { return new Promise((resolve, reject) => { setToken(token); //把token存放到cookie裡 commit('SET_TOKEN', token) //commit呼叫mutations 資料 resolve() }) }, aEdit(context, payload) { return new Promise((resolve, reject) => { setTimeout(() => { context.commit('SET_TOKEN', payload) resolve() }, 2000) }) } }, modules: { //這裡是我自己理解的是為了給全域性變數分組,所以需要寫提前宣告其他store檔案,然後引入這裡 } })
我們用vuex時通常會分功能建立多的module,單個module裡的操作大家應該很清楚,那多個module之間怎麼呼叫了?
詳細程式碼:
現在我有兩個module:user 和 menu,要在user中呼叫menu的actions方法,操作如下:
const user = { state: { permissions: [] }, mutations: { SET_PERMISSIONS: (state, permissions) => { state.permissions = permissions } }, actions: { getPermissions({commit}) { queryPermissions().then(res => { sessionStorage.setItem('permissions', JSON.stringify(res)) this.dispatch('setPermissions', res); // 調本module裡的方法 }) }, setPermissions({commit, dispatch, state, rootState}, data) { commit('SET_PERMISSIONS', data); // 本module的commit dispatch('setMenuData', data); // 調menu裡的方法 console.log(rootState.menu.menus); // 取menu裡的引數 } } } export default user const menu = { state: { menus: [] }, mutations: { SET_MENUS: (state, data) => { state.menus = data } }, actions: { setMenuData({commit, state}, data) { commit('SET_MENUS', data); } } } export default menu
解釋:
actions裡各個方法的第一個引數其實有很多屬性,只是我們平時習慣瞭解構的寫法,如setMenuData({commit, state},data)。當把第一個引數的值全輸出,如setMenuData(param,data),輸出param會發現其中包含以下屬性:
const actions = { // 根據許可權動態生成路由 async generateRoutes({ commit }) { // 執行程式碼 } }
created() { this.generateRoutes() }, methods: { ...mapActions('menu', [ 'generateRoutes' ]) }
以上為個人經驗,希望能給大家一個參考,也希望大家多多支援it145.com。
相關文章
<em>Mac</em>Book项目 2009年学校开始实施<em>Mac</em>Book项目,所有师生配备一本<em>Mac</em>Book,并同步更新了校园无线网络。学校每周进行电脑技术更新,每月发送技术支持资料,极大改变了教学及学习方式。因此2011
2021-06-01 09:32:01
综合看Anker超能充系列的性价比很高,并且与不仅和iPhone12/苹果<em>Mac</em>Book很配,而且适合多设备充电需求的日常使用或差旅场景,不管是安卓还是Switch同样也能用得上它,希望这次分享能给准备购入充电器的小伙伴们有所
2021-06-01 09:31:42
除了L4WUDU与吴亦凡已经多次共事,成为了明面上的厂牌成员,吴亦凡还曾带领20XXCLUB全队参加2020年的一场音乐节,这也是20XXCLUB首次全员合照,王嗣尧Turbo、陈彦希Regi、<em>Mac</em> Ova Seas、林渝植等人全部出场。然而让
2021-06-01 09:31:34
目前应用IPFS的机构:1 谷歌<em>浏览器</em>支持IPFS分布式协议 2 万维网 (历史档案博物馆)数据库 3 火狐<em>浏览器</em>支持 IPFS分布式协议 4 EOS 等数字货币数据存储 5 美国国会图书馆,历史资料永久保存在 IPFS 6 加
2021-06-01 09:31:24
开拓者的车机是兼容苹果和<em>安卓</em>,虽然我不怎么用,但确实兼顾了我家人的很多需求:副驾的门板还配有解锁开关,有的时候老婆开车,下车的时候偶尔会忘记解锁,我在副驾驶可以自己开门:第二排设计很好,不仅配置了一个很大的
2021-06-01 09:30:48
不仅是<em>安卓</em>手机,苹果手机的降价力度也是前所未有了,iPhone12也“跳水价”了,发布价是6799元,如今已经跌至5308元,降价幅度超过1400元,最新定价确认了。iPhone12是苹果首款5G手机,同时也是全球首款5nm芯片的智能机,它
2021-06-01 09:30:45