亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

詳解vue組件化開發(fā)-vuex狀態(tài)管理庫

 更新時(shí)間:2017年04月10日 16:22:55   作者:一步小僧  
本篇文章主要介紹了詳解vue組件化開發(fā)-vuex狀態(tài)管理庫,具有一定的參考價(jià)值,有興趣的可以了解一下。

Vuex 是一個(gè)專為 Vue.js 應(yīng)用程序開發(fā)的狀態(tài)管理模式。它采用集中式存儲(chǔ)管理應(yīng)用的所有組件的狀態(tài),并以相應(yīng)的規(guī)則保證狀態(tài)以一種可預(yù)測(cè)的方式發(fā)生變化。Vuex 也集成到 Vue 的官方調(diào)試工具 devtools extension,提供了諸如零配置的 time-travel 調(diào)試、狀態(tài)快照導(dǎo)入導(dǎo)出等高級(jí)調(diào)試功能。

以上是vuex的官方文檔對(duì)vuex的介紹,官方文檔對(duì)vuex的用法進(jìn)行了詳細(xì)的說明。這里就不再細(xì)講vuex的各個(gè)用法,寫這篇博客的目的只是幫助部分同學(xué)更快地理解并上手vuex。

為什么要用vuex

不知道現(xiàn)在讀這篇博客的同學(xué)是否有看過Vue2.0子父組件之間通信,子父組件之間的基本通信方式。我們通信的目的往往就是在組件之間傳遞數(shù)據(jù)或組件的狀態(tài)(這里將數(shù)據(jù)和狀態(tài)統(tǒng)稱為狀態(tài)),進(jìn)而更改狀態(tài)。但可以看到如果我們通過最基本的方式來進(jìn)行通信,一旦需要管理的狀態(tài)多了,代碼就會(huì)變得十分混亂。對(duì)所有狀態(tài)的管理便會(huì)顯得力不從心,尤其是多人合作的時(shí)候。

此時(shí)vuex出現(xiàn)了,他就是幫助我們把公用的狀態(tài)全抽出來放在vuex的容器中,然后根據(jù)一定的規(guī)則來進(jìn)行管理

Vuex的核心

vuex由以下幾部分組成:

  1. state
  2. mutations
  3. getters
  4. actions
  5. modules

state里面就是存放項(xiàng)目中需要多組件共享的狀態(tài)

mutations就是存放更改state里狀態(tài)的方法

getters就是從state中派生出狀態(tài),比如將state中的某個(gè)狀態(tài)進(jìn)行過濾然后獲取新的狀態(tài)。

actions就是mutation的加強(qiáng)版,它可以通過commit mutations中的方法來改變狀態(tài),最重要的是它可以進(jìn)行異步操作。

modules顧名思義,就是當(dāng)用這個(gè)容器來裝這些狀態(tài)還是顯得混亂的時(shí)候,我們就可以把容器分成幾塊,把狀態(tài)和管理規(guī)則分類來裝。這和我們創(chuàng)建js模塊是一個(gè)目的,讓代碼結(jié)構(gòu)更清晰。

實(shí)例來理解Vuex

// 實(shí)例化vuex狀態(tài)庫
var vuexStore = new Vuex.Store({
 state:{
  message:'Hello World',
  bookList:[
   {
    name:'javascript權(quán)威指南',
    price:100,
    en:'jq'
   },
   {
    name:'angularjs權(quán)威指南',
    price:80,
    en:'aq'
   },
   {
    name:'HTTP權(quán)威指南',
    price:50,
    en:'hq'
   }
  ]
 },
 mutations:{
  //同步
  showMessage:function(state,data){
   state.message = 'Store mutations changed this words。'+data;
  }
  addBook:function(state,data){
   state.bookList.push(data)
  }
 },
 getters:{
  filterPrice:function(state){
   var narr = [];
   for(var i = 0;i<state.bookList.length;i++){
    state.bookList[i].price<85 ? narr.push(state.bookList[i]) : null;
   }
   return narr;
  }
 },
 actions:{
  //異步操作
  addBook:function(context){
   setTimeout(function(){
    context.commit('addBook',{name:'HTML5權(quán)威指南',price:75});
   },2000);
  }
 },
 modules:{
  a:storeA,b:storeB
 }
});

// vue 實(shí)例
var vm = new Vue({
  el:'app',
  store:VuexStore,
  methods:{
  showMessage:function(){
      this.$store.commit('showMessage','荷載數(shù)據(jù)')
    },
  filterList:function(){
   return this.store.getters.filterPrice();
  },
  addBooks:function(){
      this.$store.dispatch('addBook')
    },
  }
});

【state】vuex核心概念有五個(gè),試想當(dāng)我們把所有的狀態(tài)從各個(gè)組件抽出來,放入了state中:message和bookList;

【mutations】某個(gè)時(shí)候,某個(gè)組件中,我們需要把state中的message改變數(shù)據(jù),我們要通過調(diào)用commit方法提交到mutations對(duì)應(yīng)的事件:commit('showMessage'),這樣就會(huì)調(diào)用mutations里showMessage方法;調(diào)用方法是如上面代碼中57行的方式;

【getters】某個(gè)時(shí)間,某個(gè)組件我們需要獲得bookList中價(jià)格小于85的所有數(shù)據(jù),vuex中允許我們通過getters來獲?。菏褂梅椒ㄈ缟洗a中60行

【actions】這個(gè)是mutations的強(qiáng)化部分,只是這個(gè)里面的函數(shù)可以異步操作,比如網(wǎng)絡(luò)請(qǐng)求等等;這里面的方法如果要更改狀態(tài),最好要通過commit()函數(shù)提交到mutations里去處理。官方是這么說的。在實(shí)例里調(diào)用一般是通過dispatch('funName')來調(diào)用的;例如實(shí)例中:66行代碼

【關(guān)于moduls】modules其實(shí)就是多個(gè)狀態(tài)管理庫,放在一個(gè)對(duì)象里,比如我們有2個(gè)狀態(tài)庫:storeA,storeB。我們?cè)趍odules里就和上面代碼中50行的寫法是一樣的。

 在取值的時(shí)候就直接在實(shí)例里調(diào)用:this.$store.state.a即可返回storeA這個(gè)store里的狀態(tài)。

這里有一個(gè)點(diǎn)要注意一下:所有子模塊里的getters對(duì)象里的方法會(huì)被合并到$store里,如果不同子模塊里有重名的方法,那么會(huì)報(bào)錯(cuò);

但是所有子模塊里actions和mutations中的方法不會(huì)被合并,重名也不會(huì)報(bào)錯(cuò)。但是當(dāng)你dispatch或者commit一個(gè)同名的事件的時(shí)候,會(huì)依次執(zhí)行每一個(gè)子模塊中的事件。

所以在不同子模塊的actions和mutations中不要寫重復(fù)的函數(shù)名稱;

使用Vuex

下面我們來講一下怎么引入一個(gè)Vuex協(xié)助我們管理狀態(tài):

首先當(dāng)然要引入Vuex.js;

然后,我們新建一個(gè)vuex實(shí)例

 var store = new VuexStore({
 state:{
  } ,
  mountations:{
  },  
 })

創(chuàng)建好store后我們需要把這個(gè)store注入到vue的實(shí)例和組件中,

 var vm = new Vue({
 el:'#app',
 store:store 
 })

然后我們就能像上面介紹的方法使用了。

最后多說一嘴,官方建議的目錄結(jié)構(gòu)是吧mutations,actions,getters等一系列,都分開放在不同的目錄,便于多人開發(fā)與維護(hù)。

vue到此已經(jīng)研究了很多。行百里者半九十,還需要深入研究。個(gè)人對(duì)vue2.0的總結(jié)demo已上傳至gitHub。地址:https://github.com/HUA1/vue2-summary.git

本文到此結(jié)束,所涉及的vue版本是2.0.x;vuex版本是:2.2.1。希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。

相關(guān)文章

  • 在Vue.js應(yīng)用中實(shí)現(xiàn)分布式搜索和全文搜索

    在Vue.js應(yīng)用中實(shí)現(xiàn)分布式搜索和全文搜索

    分布式搜索和全文搜索在現(xiàn)代應(yīng)用程序中變得越來越重要,因?yàn)樗鼈兛梢詭椭脩艨焖俨檎液蜋z索大量數(shù)據(jù),Elasticsearch是一種強(qiáng)大的分布式搜索引擎,本文將介紹如何在Vue.js應(yīng)用程序中實(shí)現(xiàn)分布式搜索和全文搜索,以及如何與Elasticsearch集成,需要的朋友可以參考下
    2023-11-11
  • vue-cli 3.0 版本與3.0以下版本在搭建項(xiàng)目時(shí)的區(qū)別詳解

    vue-cli 3.0 版本與3.0以下版本在搭建項(xiàng)目時(shí)的區(qū)別詳解

    這篇文章主要介紹了vue-cli 3.0 版本與3.0以下版本在搭建項(xiàng)目時(shí)的區(qū)別詳解,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧
    2018-12-12
  • 如何用Vue實(shí)現(xiàn)父子組件通信

    如何用Vue實(shí)現(xiàn)父子組件通信

    這篇文章主要介紹了如何用Vue實(shí)現(xiàn)父子組件通信,對(duì)Vue感興趣的同學(xué),可以參考下
    2021-05-05
  • axios攔截設(shè)置和錯(cuò)誤處理方法

    axios攔截設(shè)置和錯(cuò)誤處理方法

    下面小編就為大家分享一篇axios攔截設(shè)置和錯(cuò)誤處理方法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧
    2018-03-03
  • elementUI同一頁面展示多個(gè)Dialog的實(shí)現(xiàn)

    elementUI同一頁面展示多個(gè)Dialog的實(shí)現(xiàn)

    這篇文章主要介紹了elementUI同一頁面展示多個(gè)Dialog的實(shí)現(xiàn),文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2020-11-11
  • vue3?v-bind="$attrs"繼承組件全部屬性的解決方案

    vue3?v-bind="$attrs"繼承組件全部屬性的解決方案

    這篇文章主要介紹了vue3?v-bind=“$attrs“?繼承組件全部屬性的解決方案,本文通過實(shí)例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2023-06-06
  • vue修改數(shù)據(jù)視圖更新原理學(xué)習(xí)

    vue修改數(shù)據(jù)視圖更新原理學(xué)習(xí)

    這篇文章主要為大家介紹了vue修改數(shù)據(jù)視圖更新原理學(xué)習(xí),有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2023-11-11
  • vuepress打包之后頁面樣式丟失問題的兩種解決方式

    vuepress打包之后頁面樣式丟失問題的兩種解決方式

    這篇文章主要介紹了vuepress打包之后頁面樣式丟失問題的兩種解決方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2024-07-07
  • Vue中瀑布流布局與圖片加載優(yōu)化的實(shí)現(xiàn)

    Vue中瀑布流布局與圖片加載優(yōu)化的實(shí)現(xiàn)

    本文主要介紹了Vue中瀑布流布局與圖片加載優(yōu)化的實(shí)現(xiàn),文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2023-06-06
  • vue如何獲取配置代理文件中的api地址值

    vue如何獲取配置代理文件中的api地址值

    這篇文章主要介紹了vue如何獲取配置代理文件中的api地址值,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2022-04-04

最新評(píng)論