Vue項目--vuex的使用與理解

1.在項目main.js中引入store,并掛載

import store from './store'
......
new Vue({
  el: '#app',
  render: h => h(App),
//把store對象提供給‘store’選項,這可以把store的實例注入所有的組件
  store
})

2.建立store倉庫贱呐,結(jié)構(gòu)如下


image.png

3.state的理解
單一狀態(tài)樹
我的理解就是:state狀態(tài)就是數(shù)據(jù)源
比如很多個視圖層文件(組件)都是同一個數(shù)據(jù)來源得哆,不同視圖的操作都需要改為同一個數(shù)據(jù)源醋火。那么就可以把這個數(shù)據(jù)提出來,存在state中潜圃。


image.png

4.getters的理解
getters是對state做一些映射----基礎(chǔ)的代理

export const singer = state => state.singer

有時候我們需要從 store 中的 state 中派生出一些狀態(tài)

// 計算屬性
export const currentSong = (state) => {
  return state.playlist[state.currentIndex] || {}
}

上面的currentSong就是通過playlist數(shù)據(jù)與currentIndex計算而來的


image.png

5.mapGetters輔助函數(shù)
mapGetters輔助函數(shù)缸棵,僅僅是將store中的 getters 映射到局部計算屬性:
首先在組件中引入:

import {mapGetters} from 'vuex'

其次,在計算屬性computed中使用

computed: {
  // 使用對象展開運算符將 getters 混入 computed 對象中
  ...mapGetters([
    'playing'
  // 'playing'對應(yīng)getters中的playing
  // 如果想給getter屬性換個名字: 'newplaying': 'playing'
  ])
}
image.png

6.mutation-types的理解
存儲mutation相關(guān)的狀態(tài)常量


image.png

7.mutations的理解
更改 Vuex 的 store 中的狀態(tài)的唯一方法是提交 mutation


image.png

8.mapMutations輔助函數(shù)
首先谭期,組件中引入
import {mapMutations} from 'vuex'

其次堵第,在methods中使用

methods: {
      back() {
        this.setFullScreen(false)
      },
      open() {
        this.setFullScreen(true)
      },
      changeMode() {
        const mode = (this.mode + 1) % 3
        this.setPlayMode(mode)
        let list = null
        if (mode === playMode.random) {
          list = shuffle(this.sequenceList)
        } else {
          list = this.sequenceList
        }
        this._resetcurrentIndex(list)
        this.setPlayList(list)
      },
      ...mapMutations({
        setFullScreen: 'SET_FULL_SCREEN',
        setPlayingState: 'SET_PLAYING_STATE',
        setCurrentIndex: 'SET_CURRENT_INDEX',
        setPlayMode: 'SET_PLAY_MODE',
        setPlayList: 'SET_PLAYLIST'
      })
    }
我的理解:

這里的字符串 'SET_FULL_SCREEN',對應(yīng)的是mutation-types中的字符串'SET_FULL_SCREEN'隧出,setFullScreen是新起的對應(yīng)的事件名踏志,方便在methods中使用。

9.actions的理解
mutations提交同步狀態(tài)的改變胀瞪;
actions提交異步的狀態(tài)改變针余,實際上actions是先將改變反饋到mutation,再通過mutation進行提交凄诞。


image.png

10.index.js
可以理解為入口圆雁,或者接口


image.png

總結(jié)一番:

以上截圖是我做得一個音樂APP項目中的截圖。
以播放器全屏帆谍、縮小為例:
假設(shè)處于當(dāng)前模式(如圖):


image.png

當(dāng)點擊左上角的向下箭頭圖標(biāo)的時候:
1)觸發(fā)methods中的back()函數(shù),
2)提交數(shù)據(jù)false

methods: {
      back() {
        this.setFullScreen(false)
      },
      ...mapMutations({
        setFullScreen: 'SET_FULL_SCREEN',
      })
    }

3)back()函數(shù)中的
this.setFullScreen
對應(yīng)mapMutations中的
setFullScreen: 'SET_FULL_SCREEN',
4)mapMutations中的
setFullScreen: 'SET_FULL_SCREEN',
對應(yīng)伪朽,mutation-types中的
export const SET_FULL_SCREEN = 'SET_FULL_SCREEN'
5)再到mutations中的

[types.SET_FULL_SCREEN](state, flag) {
    state.fullScreen = flag
  },

其中參數(shù)flag對應(yīng)back()函數(shù)的參數(shù)false
6)通過mutations改變state的狀態(tài)
7)state.fullScreen的狀態(tài)變?yōu)閒alse,映射到getters中

export const fullScreen = state => state.fullScreen

在通過mapGetters插入到組件中

...mapGetters([
   'fullScreen'
])

8)觸發(fā)

<div class="mini-player" v-show="!fullScreen" @click="open">

播放器縮小汛蝙,如下圖所示

image.png
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末烈涮,一起剝皮案震驚了整個濱河市,隨后出現(xiàn)的幾起案子窖剑,更是在濱河造成了極大的恐慌坚洽,老刑警劉巖,帶你破解...
    沈念sama閱讀 218,858評論 6 508
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件西土,死亡現(xiàn)場離奇詭異酪术,居然都是意外死亡,警方通過查閱死者的電腦和手機翠储,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,372評論 3 395
  • 文/潘曉璐 我一進店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來橡疼,“玉大人援所,你說我怎么就攤上這事⌒莱” “怎么了住拭?”我有些...
    開封第一講書人閱讀 165,282評論 0 356
  • 文/不壞的土叔 我叫張陵,是天一觀的道長。 經(jīng)常有香客問我滔岳,道長杠娱,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 58,842評論 1 295
  • 正文 為了忘掉前任谱煤,我火速辦了婚禮摊求,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘刘离。我一直安慰自己室叉,他們只是感情好,可當(dāng)我...
    茶點故事閱讀 67,857評論 6 392
  • 文/花漫 我一把揭開白布硫惕。 她就那樣靜靜地躺著茧痕,像睡著了一般。 火紅的嫁衣襯著肌膚如雪恼除。 梳的紋絲不亂的頭發(fā)上踪旷,一...
    開封第一講書人閱讀 51,679評論 1 305
  • 那天,我揣著相機與錄音豁辉,去河邊找鬼令野。 笑死,一個胖子當(dāng)著我的面吹牛秋忙,可吹牛的內(nèi)容都是我干的彩掐。 我是一名探鬼主播,決...
    沈念sama閱讀 40,406評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼灰追,長吁一口氣:“原來是場噩夢啊……” “哼堵幽!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起弹澎,我...
    開封第一講書人閱讀 39,311評論 0 276
  • 序言:老撾萬榮一對情侶失蹤朴下,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后苦蒿,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體殴胧,經(jīng)...
    沈念sama閱讀 45,767評論 1 315
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 37,945評論 3 336
  • 正文 我和宋清朗相戀三年佩迟,在試婚紗的時候發(fā)現(xiàn)自己被綠了团滥。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 40,090評論 1 350
  • 序言:一個原本活蹦亂跳的男人離奇死亡报强,死狀恐怖灸姊,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情秉溉,我是刑警寧澤力惯,帶...
    沈念sama閱讀 35,785評論 5 346
  • 正文 年R本政府宣布碗誉,位于F島的核電站,受9級特大地震影響父晶,放射性物質(zhì)發(fā)生泄漏哮缺。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點故事閱讀 41,420評論 3 331
  • 文/蒙蒙 一甲喝、第九天 我趴在偏房一處隱蔽的房頂上張望尝苇。 院中可真熱鬧,春花似錦俺猿、人聲如沸茎匠。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,988評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽诵冒。三九已至,卻和暖如春谊惭,著一層夾襖步出監(jiān)牢的瞬間汽馋,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 33,101評論 1 271
  • 我被黑心中介騙來泰國打工圈盔, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留豹芯,地道東北人。 一個月前我還...
    沈念sama閱讀 48,298評論 3 372
  • 正文 我出身青樓驱敲,卻偏偏與公主長得像铁蹈,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子众眨,可洞房花燭夜當(dāng)晚...
    茶點故事閱讀 45,033評論 2 355