vuex相關(guān)內(nèi)容

Vuex是什么

官網(wǎng)中是這樣描述Vuex的:Vuex 是一個(gè)專為 Vue.js 應(yīng)用程序開發(fā)的狀態(tài)管理模式抡草。它采用集中式存儲(chǔ)管理應(yīng)用的所有組件的狀態(tài)自脯,并以相應(yīng)的規(guī)則保證狀態(tài)以一種可預(yù)測的方式發(fā)生變化。Vuex 也集成到 Vue 的官方調(diào)試工具 devtools extension允悦,提供了諸如零配置的 time-travel 調(diào)試很魂、狀態(tài)快照導(dǎo)入導(dǎo)出等高級調(diào)試功能趴樱。
由于官方文檔中的描述太過官方化,本人對vuex的理解就是vuex是對各個(gè)組件中的數(shù)據(jù)進(jìn)行管理尚卫,使組件中數(shù)據(jù)間的傳遞更加便利化归榕,并且vuex中存在數(shù)據(jù)不會(huì)因?yàn)榻M件對數(shù)據(jù)進(jìn)行更改而改變。

ok吱涉,我們現(xiàn)在已經(jīng)明白vuex是什么了刹泄,那么vuex應(yīng)該如何使用呢?

Vuex的模板定義

import Vue from 'vue'
import Vuex from 'vuex'
Vue.use(Vuex)
const store = new Vuex.Store({
  state: {
  },
  actions: {
  },
  mutations: {
  },
  getters: {
  },  
  modules: {
    
  }
})
export default store

看到這各位看官一定迷糊了怎爵,state循签,actions,mutations疙咸,getters县匠,modules又是些什么東西呢?

  • state:state 定義了應(yīng)用狀態(tài)的數(shù)據(jù)結(jié)構(gòu),同樣可以在這里設(shè)置默認(rèn)的初始狀態(tài)乞旦。
  • actions:Actions 即是定義提交觸發(fā)更改信息的描述贼穆,常見的例子有從服務(wù)端獲取數(shù)據(jù),在數(shù)據(jù)獲取完成后會(huì)調(diào)用store.commit()來調(diào)用更改 Store 中的狀態(tài)兰粉」嗜可以在組件中使用dispatch來發(fā)出 Actions。
  • mutations:調(diào)用 mutations 是唯一允許更新應(yīng)用狀態(tài)的地方玖姑。
  • getters:Getters 允許組件從 Store 中獲取數(shù)據(jù)愕秫,譬如我們可以從 Store 中的 projectList 中篩選出已完成的項(xiàng)目列表:
  • modules:modules 對象允許將單一的 Store 拆分為多個(gè) Store 的同時(shí)保存在單一的狀態(tài)樹中。

Vuex的運(yùn)行流程

vuex.的運(yùn)行流程

那么在vue中vuex是怎么用的呢,看代碼:
先看沒有引入vuex的代碼

<script src="https://unpkg.com/vue/dist/vue.js"></script>
<div id="app">
  <p>{{count}}
    <button @click="inc">+</button>
    <button @click="dec">-</button>
  </p>
</div>
<script>
new Vue({
  el:'#app',
  data () {
    return {
      count: 0
    }
  },
  methods: {
    inc () {
      this.count++
    },
    dec () {
      this.count--
    }
  }
})
</script>

引入了vuex的代碼

<script src="https://unpkg.com/vue/dist/vue.js"></script>
<script src="https://unpkg.com/vuex@next"></script>
<div id="app">
  <p>{{count}}
    <button @click="inc">+</button>
    <button @click="dec">-</button>
  </p>
</div>
<script>

const store = new Vuex.Store({
  state: {
    count: 0
  },
  mutations: {
      inc: state => state.count++,
    dec: state => state.count--
  }
})

const app = new Vue({
  el: '#app',
  computed: {
    count () {
        return store.state.count
    }
  },
  methods: {
    inc () {
      store.commit('inc')
    },
    dec () {
        store.commit('dec')
    }
  }
})
</script>

以上代碼復(fù)制之后都是可以在本地運(yùn)行起來的
我們來看看引入了vuex都有哪些變化:
   1.新的代碼添加了對vuex@next腳本的依賴焰络。這是當(dāng)然的戴甩,因?yàn)槟阈枰褂胿uex的技術(shù),當(dāng)然需要引用它
 ∩帘恕2.methods數(shù)組還是這兩個(gè)方法甜孤,這和demo1是一樣的;但是方法內(nèi)的計(jì)算邏輯畏腕,不再是在函數(shù)內(nèi)進(jìn)行缴川,而是提交給store對象!這是一個(gè)新的對象描馅!
 “芽洹3.count數(shù)據(jù)也不再是一個(gè)data函數(shù)返回的對象的屬性;而是通過計(jì)算字段來返回铭污,并且在計(jì)算字段內(nèi)的代碼也不是自己算的恋日,而是轉(zhuǎn)發(fā)給store對象。再一次store對象况凉!

這些東西全都是網(wǎng)上抄的以下是本人的理解

  • state:一般情況下設(shè)置為空,用作數(shù)據(jù)的初始化
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市各拷,隨后出現(xiàn)的幾起案子刁绒,更是在濱河造成了極大的恐慌,老刑警劉巖烤黍,帶你破解...
    沈念sama閱讀 216,919評論 6 502
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件知市,死亡現(xiàn)場離奇詭異,居然都是意外死亡速蕊,警方通過查閱死者的電腦和手機(jī)嫂丙,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,567評論 3 392
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來规哲,“玉大人跟啤,你說我怎么就攤上這事。” “怎么了隅肥?”我有些...
    開封第一講書人閱讀 163,316評論 0 353
  • 文/不壞的土叔 我叫張陵竿奏,是天一觀的道長。 經(jīng)常有香客問我腥放,道長,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 58,294評論 1 292
  • 正文 為了忘掉前任茬末,我火速辦了婚禮变姨,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘种柑。我一直安慰自己岗仑,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,318評論 6 390
  • 文/花漫 我一把揭開白布莹规。 她就那樣靜靜地躺著赔蒲,像睡著了一般。 火紅的嫁衣襯著肌膚如雪良漱。 梳的紋絲不亂的頭發(fā)上舞虱,一...
    開封第一講書人閱讀 51,245評論 1 299
  • 那天,我揣著相機(jī)與錄音母市,去河邊找鬼矾兜。 笑死,一個(gè)胖子當(dāng)著我的面吹牛患久,可吹牛的內(nèi)容都是我干的椅寺。 我是一名探鬼主播,決...
    沈念sama閱讀 40,120評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼蒋失,長吁一口氣:“原來是場噩夢啊……” “哼返帕!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起篙挽,我...
    開封第一講書人閱讀 38,964評論 0 275
  • 序言:老撾萬榮一對情侶失蹤荆萤,失蹤者是張志新(化名)和其女友劉穎,沒想到半個(gè)月后铣卡,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體链韭,經(jīng)...
    沈念sama閱讀 45,376評論 1 313
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,592評論 2 333
  • 正文 我和宋清朗相戀三年煮落,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了敞峭。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 39,764評論 1 348
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡蝉仇,死狀恐怖旋讹,靈堂內(nèi)的尸體忽然破棺而出殖蚕,到底是詐尸還是另有隱情,我是刑警寧澤骗村,帶...
    沈念sama閱讀 35,460評論 5 344
  • 正文 年R本政府宣布嫌褪,位于F島的核電站,受9級特大地震影響胚股,放射性物質(zhì)發(fā)生泄漏笼痛。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,070評論 3 327
  • 文/蒙蒙 一琅拌、第九天 我趴在偏房一處隱蔽的房頂上張望缨伊。 院中可真熱鬧,春花似錦进宝、人聲如沸刻坊。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,697評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽谭胚。三九已至,卻和暖如春未玻,著一層夾襖步出監(jiān)牢的瞬間灾而,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 32,846評論 1 269
  • 我被黑心中介騙來泰國打工扳剿, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留旁趟,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 47,819評論 2 370
  • 正文 我出身青樓庇绽,卻偏偏與公主長得像锡搜,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個(gè)殘疾皇子瞧掺,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,665評論 2 354

推薦閱讀更多精彩內(nèi)容