国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > JavaScript > 正文

vue store之狀態管理模式的詳細介紹

2019-11-19 11:21:03
字體:
來源:轉載
供稿:網友

狀態管理

一、狀態管理(vuex)簡介

uex是專為vue.js應用程序開發的狀態管理模式。它采用集中存儲管理應用的所有組件的狀態,并以相應的規則保證狀態以一種可預測的方式發生變化。vuex也集成刀vue的官方調試工具devtools extension,提供了諸如零配置的time-travel調試、狀態快照導入導出等高級調試功能。

Vuex 的思想

當我們在頁面上點擊一個按鈕,它會處發(dispatch)一個action, action 隨后會執行(commit)一個mutation, mutation 立即會改變state, state 改變以后,我們的頁面會state 獲取數據,頁面發生了變化。 Store 對象,包含了我們談到的所有內容,action, state, mutation,所以是核心了

官方demo

const store = new Vuex.Store({ state: {  count: 0 }, mutations: {  increment (state) {   state.count++  } }})

二、狀態管理核心狀態管理有5個核心,分別是state、getter、mutation、action以及module。

分別簡單的介紹一下它們:

1、state

state為單一狀態樹,在state中需要定義我們所需要管理的數組、對象、字符串等等,只有在這里定義了,在vue.js的組件中才能獲取你定義的這個對象的狀態。

2、getter

getter有點類似vue.js的計算屬性,當我們需要從store的state中派生出一些狀態,那么我們就需要使用getter,getter會接收state作為第一個參數,而且getter的返回值會根據它的依賴被緩存起來,只有getter中的依賴值(state中的某個需要派生狀態的值)發生改變的時候才會被重新計算。

3、mutation

更改store中state狀態的唯一方法就是提交mutation,就很類似事件。每個mutation都有一個字符串類型的事件類型和一個回調函數,我們需要改變state的值就要在回調函數中改變。我們要執行這個回調函數,那么我們需要執行一個相應的調用方法:store.commit。

4、action

action可以提交mutation,在action中可以執行store.commit,而且action中可以有任何的異步操作。在頁面中如果我們要嗲用這個action,則需要執行store.dispatch5、module module其實只是解決了當state中很復雜臃腫的時候,module可以將store分割成模塊,每個模塊中擁有自己的state、mutation、action和getter。

簡單的 store 模式

var store = { debug: true, state: {  message: 'Hello!' }, setMessageAction (newValue) {  if (this.debug) console.log('setMessageAction triggered with', newValue)  this.state.message = newValue }, clearMessageAction () {  if (this.debug) console.log('clearMessageAction triggered')  this.state.message = '' }}

所有 store 中 state 的改變,都放置在 store 自身的 action 中去管理。這種集中式狀態管理能夠被更容易地理解哪種類型的 mutation 將會發生,以及它們是如何被觸發。當錯誤出現時,我們現在也會有一個 log 記錄 bug 之前發生了什么。

此外,每個實例/組件仍然可以擁有和管理自己的私有狀態:

var vmA = new Vue({ data: {  privateState: {},  sharedState: store.state }})var vmB = new Vue({ data: {  privateState: {},  sharedState: store.state }})

三.在

主站蜘蛛池模板: 张家港市| 察隅县| 安岳县| 花垣县| 民和| 虹口区| 曲麻莱县| 梧州市| 乌拉特后旗| 辽宁省| 小金县| 南澳县| 集贤县| 筠连县| 梨树县| 夹江县| 甘孜县| 利辛县| 鄱阳县| 普洱| 郁南县| 元谋县| 罗江县| 广水市| 东平县| 乌兰县| 成都市| 阿拉善右旗| 元阳县| 米林县| 凤庆县| 全州县| 濮阳市| 繁昌县| 彰化县| 陆良县| 海林市| 焦作市| 福鼎市| 杂多县| 临夏市|