亚洲激情专区-91九色丨porny丨老师-久久久久久久女国产乱让韩-国产精品午夜小视频观看

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

vuex狀態管理模式的示例分析

發布時間:2021-07-22 15:54:59 來源:億速云 閱讀:128 作者:小新 欄目:web開發

小編給大家分享一下vuex狀態管理模式的示例分析,相信大部分人都還不怎么了解,因此分享這篇文章給大家參考一下,希望大家閱讀完這篇文章后大有收獲,下面讓我們一起去了解一下吧!

一、前言

本次接受一個BI系統,要求是能夠接入數據源-得到數據集-對數據集進行處理-展現為數據的可視化,這一個系統為了接入公司自身的產品,后端技術采用spring boot,前端采用vue+vuex+axios的項目架構方式,vuex作為vue的狀態管理,是尤為重要的部分。

二、vuex簡單使用

安裝vuex

cnpm install vuex --save

在src目錄下建立文件夾,命名為store,建立index.js

如圖所示:

vuex狀態管理模式的示例分析

在index.js中引入vue和vuex狀態管理,并導出vuex,代碼如下:

import Vue from 'vue'
import Vuex from 'vuex'
Vue.use(Vuex)
const store = new Vuex.Store({
  state: {
   token: 0
  },
 })
 export default store;

在main.js中引入剛剛創建好的store并作為vue的store

import Vue from 'vue'
import App from './App.vue'
import store from './store/index'
Vue.config.productionTip = false
new Vue({
 render: h => h(App)
 ,
 store
}).$mount('#app')

獲得store里的token

在vue的組件中,想要獲得vuex里的全局數據,可以把vue看做一個類,在其下面有許多屬性,其中有我們剛剛注入的vuex,如圖

vuex狀態管理模式的示例分析

我們可以看到vue他本身就是一個json,在其下有$store這個對象,而$store下又有state,state下得就是我們存儲在vue中的全局數據,在組件中通過this.$store.state.token即可獲得我們的數據。

三、vuex的核心概念之getters

有時候我們需要在獲得的數據做一些簡單的過濾或者處理的時候,getters就起到作用了。

代碼如下

getters:{
    getToken(state){
     return state.token;
    }

同直接獲取token的方式一樣。getters也已經掛載到了$store下,故,我們可以通過this.$store.state.getters.getToken的方式,調用其函數。 但vuex為我們提供了mapGetters能夠將其映射到對應的getters的方法上去,用法如下所示

import {mapGetters,mapActions} from 'vuex'
export default {
 name: 'app',
 components: {
  HelloWorld
 },
 computed:{
  ...mapGetters(["getToken"])
 },
 mounted() {
   console.log(this.getToken)
  console.log(this.$store.getters.getToken)
 
 },
}

映射出來的getters仍然掛載在vue上,如圖所示

vuex狀態管理模式的示例分析

四、vuex的核心概念之mutations與actions

我們可以吧mutations理解成一個事件函數,而actions就是觸發器,通過actions,發起動作。

簡單實例代碼如下。

 mutations:{
     setToken(state,n){
      state.token=state.token+n;
     }
    },
    actions:{
     setToken({commit},n){
      commit('setToken',n)
     }
    }

在組件中的使用,同getters的用法,代碼如下

import {mapGetters,mapActions} from 'vuex'
export default {
 name: 'app',
 components: {
  HelloWorld
 },
 computed:{
  ...mapGetters(["getToken"])
 },
 
 mounted() {

  console.log(this)
  console.log(this.setToken(1))
  console.log(this.getToken)
 
 },methods:{
    ...mapActions(["setToken"])
 },

在vue的json中,同樣可以找到相同的屬性。

vuex狀態管理模式的示例分析

五、vuex核心概念之mudules

vuex允許我們將store分為不同的模塊,每個單獨的模塊具備getters,state,mutations,actions這四個store核心,

需要注意的是如果在模塊內部加入了namesapced:true這一個屬性。在取值的時候需要做一點細微的變動,通過mapGetters火mapActions映射時需要將模塊名作為路勁,來獲得該模塊的getters,和actions,模塊化代碼如下

import Vue from 'vue'
import Vuex from 'vuex'
Vue.use(Vuex)
const moduleA = {
 namespaced:true,
 state: { a:1 },
 mutations: { },
 actions: { },
 getters: { geta(state){
  return state.a;
 } }
}

const moduleB = {
 namespaced:true,
 state: { b:1},
 mutations: { },
 actions: {}
}

const store = new Vuex.Store({ 
 
  state: {
   token: 0
  },
  getters:{
    getToken(state){
     return state.token;
    },
   
  } , mutations:{
   setToken(state,n){
     state.token=state.token+n;
   }
  },
  actions:{
   setToken({commit},n){
    commit('setToken',n)
   }
  },
  modules: {
   a: moduleA,
   b: moduleB
  },
 })
 export default store;

在組件中獲得模塊A的值得時候,我們來看一下geta這個getters屬性,在vue中的狀態,如圖所示

vuex狀態管理模式的示例分析

geta為模塊a下得getters屬性,在獲取的時候就需要這樣

 computed:{
  // ...mapGetters(["getToken"])
  ...mapGetters("a",["geta"])
 },
 
 mounted() {

  console.log(this)
  console.log(this.geta)

而如果模塊沒有命令空間的話,vuex會自動將模塊內的getters,actions注入為全局的,直接按照原來個獲取方式就可以了。

以上是“vuex狀態管理模式的示例分析”這篇文章的所有內容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內容對大家有所幫助,如果還想學習更多知識,歡迎關注億速云行業資訊頻道!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

兖州市| 乌海市| 东莞市| 土默特左旗| 永宁县| 正阳县| 绥化市| 湄潭县| 牙克石市| 兴国县| 开封县| 兴海县| 荔浦县| 连江县| 钟山县| 定结县| 河津市| 安福县| 桐柏县| 锦屏县| 儋州市| 梁平县| 东莞市| 炎陵县| 孝昌县| 高唐县| 依安县| 张北县| 宣武区| 博湖县| 蕉岭县| 黑龙江省| 资中县| 盘锦市| 晴隆县| 金山区| 佛冈县| 措勤县| 新巴尔虎左旗| 南木林县| 文登市|