淺談vuex

通過購物車的一個案列厘灼,把vuex學(xué)習(xí)了一篇。

vuex概念淺談

Vuex 是一個專為 Vue.js 應(yīng)用程序開發(fā)的狀態(tài)管理模式咽瓷。它采用集中式存儲管理應(yīng)用的所有組件的狀態(tài)设凹,并以相應(yīng)的規(guī)則保證狀態(tài)以一種可預(yù)測的方式發(fā)生變化。簡單的來說茅姜,就是數(shù)據(jù)共用闪朱,對數(shù)據(jù)集中起來進行統(tǒng)一的管理。

如果您的應(yīng)用夠簡單钻洒,您最好不要使用 Vuex奋姿。一個簡單的 global event bus 就足夠您所需了。但是素标,如果您需要構(gòu)建是一個中大型單頁應(yīng)用称诗,您很可能會考慮如何更好地在組件外部管理狀態(tài),Vuex 將會成為自然而然的選擇头遭。

核心概念主要有這些

  • State
    Vuex 使用單一狀態(tài)樹——是的粪狼,用一個對象就包含了全部的應(yīng)用層級狀態(tài),將所需要的數(shù)據(jù)寫放這里任岸,類似于data再榄。
  • Getter
    有時候我們需要從 store 中的 state 中派生出一些狀態(tài),使用Getter享潜,類似于computed困鸥。
  • Mutation
    更改 Vuex 的 store 中的狀態(tài)的唯一方法,類似methods。
  • Action
    Action 提交的是 mutation疾就,而不是直接變更狀態(tài)澜术,可以包含任意異步操作,這里主要是操作異步操作的猬腰,使用起來幾乎和mutations方法一模一樣,類似methods鸟废。
  • Module
    當(dāng)應(yīng)用變得非常復(fù)雜時,store 對象就有可能變得相當(dāng)臃腫姑荷。Vuex 允許我們將 store 分割成模塊(module)盒延。每個模塊擁有自己的 state、mutation鼠冕、action添寺、getter佩微、甚至是嵌套子模塊补憾。

vuex

首先需要創(chuàng)建一個Vue項目
# 全局安裝 vue-cli
$ npm install --global vue-cli
# 創(chuàng)建一個基于 webpack 模板的新項目
$ vue init webpack my-project
# 安裝依賴杖玲,走你
$ cd my-project
$ npm install
$ npm run dev
安裝vuex
npm install --save vuex
對vuex進行配置

1.創(chuàng)建一個store文件夾

2.在store文件夾下創(chuàng)建如圖的一系列js文件


這里寫圖片描述

3.在main.js文件中引入上面創(chuàng)建的store.js

import store from './store' 
new Vue({
  el: '#app',
  store,  //將store暴露出來
  components: { App },
  template: '<App/>'
})

4.將要存放的數(shù)據(jù)寫在state對象中咆蒿,state則存寫在index.js文件中墩邀。

import Vue from 'vue'
import Vuex from 'vuex'
import mutations from './mutations'
import actions from './actions'
import getters from './getters'
import shop from './modules/shop'

Vue.use(Vuex)
const state = {
  goods: [
    {
      id: '0',
      name: 'vivo-X20Plus屏幕指紋版',
      hint: '逆光也清晰队秩,照亮你的美',
      price: 3596.00,
      num: 0,
      img: require('../assets/v.jpg')
    },
    {
      id: '1',
      name: '華為mate10Plus',
      hint: '真正的人工智能芯片',
      price: 4999.00,
      num: 0,
      img: require('../assets/h.jpeg')
    },
    {
      id: '2',
      name: '華為mate10Plus',
      hint: '真正的人工智能芯片',
      price: 4999.00,
      num: 0,
      img: require('../assets/v.jpg')
    }
  ],
  totalPrice: 0.00,
  totalNum: 0
}

export default new Vuex.Store({
  state,
  mutations,
  actions,
  getters,
  modules: {
    shop //shop模塊
  }
})

5.將改變state原始數(shù)據(jù)的方法寫在mutation.js文件中奈嘿,可以使用常量替代 Mutation 事件類型暮胧,用不用常量取決于你——在需要多人協(xié)作的大型項目中泞边,這會很有幫助胶坠。可以讓你的代碼合作者對整個 app 包含的 mutation 一目了然繁堡。

// 使用常量沈善,這是mutation-type.js文件
export const ADD_CART = 'ADD_CART'
export const REDUCE_CART = 'REDUCE_CART'
// 這是mutation.js文件
import {
  ADD_CART,
  REDUCE_CART
} from './mutation-types.js'
export default {
  [ADD_CART] (state, id) {
    state.goods[id].num++
    state.totalNum++
    state.totalPrice += state.goods[id].price
    // console.log(state.totalPrice)
  },
  [REDUCE_CART] (state, id) {
    if (state.goods[id].num > 0) {
      state.goods[id].num--
      state.totalNum--
      state.totalPrice -= state.goods[id].price
    }
  }
}

6.對state數(shù)據(jù)派生出一些狀態(tài),例如需要知道商品的個數(shù)

const getters = {
  goods_obj: state => state.goods,
  goods_length: state => state.goods.length
}
export default getters

7.使用vuex椭蹄,獲取數(shù)據(jù)闻牡,方法。

<template>
  <div class="hello">
    <ul class="shop_container">
      <li v-for="item in $store.state.goods" :key="item.id" class="shop_container_li">
        <div class="shop_img">
          <img :src="item.img" alt="" width="100%" height="100%"/>
        </div>
        <div class="shop_detail">
          <p>{{item.name}}</p>
          <p>{{item.hint}}</p>
          <p>¥{{item.price}}</p>
          <p>
            <span class="shop_reduce" @click="reduce_num(item.id)">-</span>
            <span class="shop_num">{{item.num}}</span>
            <span class="shop_add" @click="add_num(item.id)">+</span>
          </p>
        </div>
      </li>
    </ul>
    <div class="foot">
      <div class="total_price">
        <span>合計:¥{{totalPrice}}</span>
      </div>
      <div class="total_num" :class="{payment: totalNum}">
        <span>去結(jié)賬:{{totalNum}}</span>
      </div>
    </div>
  </div>
</template>

<script>
import {mapState, mapMutations, mapGetters} from 'vuex'
export default {
  name: 'HelloWorld',
  data () {
    return {
    }
  },
  created () {
    // console.log(this.goods)
    // console.log(this.goods_obj)
    // console.log(this.goods_length)
    // console.log(this.$store.state.shop)  // 模塊化 Vuex允許我們將 store 分割成模塊(module)每個模塊擁有自己的 state绳矩、mutation罩润、action、getter翼馆、
  },
  computed: {
    ...mapState([
    // 獲取state中的數(shù)據(jù)可以通過mapState輔助函數(shù)獲取割以,也可以直接獲取 例:this.$store.state.goods
      'goods', 'totalPrice', 'totalNum'
    ]),
    ...mapGetters([
      'goods_obj', 'goods_length'
    ])
  },
  methods: {
    ...mapMutations([
    // 獲取mutation中的方法可以通過mapMutations 輔助函數(shù)獲取,也可以直接獲取应媚。
      'ADD_CART'
      // 'REDUCE_CART'
    ]),
    reduce_num (id) {
      // this.REDUCE_CART(id)
      this.$store.commit('REDUCE_CART', id) //也可以直接獲取
    },
    add_num (id) {
      this.ADD_CART(id) //通過mapMutations 輔助函數(shù)獲取
    }
  }
}
</script>

8.假如數(shù)據(jù)過多严沥,復(fù)雜,可以進行模塊化來開發(fā)中姜,可以將上述的state消玄,mutation跟伏,action等可以同時寫在shop.js文件中,此時shop就是一個模塊了翩瓜。

總結(jié)

若數(shù)據(jù)不是很多受扳,也不復(fù)雜,我們也可以在構(gòu)造vue實例data中存放我們所需要的共用數(shù)據(jù)兔跌。一旦數(shù)據(jù)較多勘高,復(fù)雜,vuex是一個非常不錯的選擇坟桅,對于狀態(tài)管理华望。

努力學(xué)習(xí)中,希望能和大神一起桦卒。

github地址:https://github.com/flym1013/vuexDemo

效果預(yù)覽地址: https://flym1013.github.io/vuexDemoBuild/

效果圖預(yù)覽

這里寫圖片描述
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市匿又,隨后出現(xiàn)的幾起案子方灾,更是在濱河造成了極大的恐慌,老刑警劉巖碌更,帶你破解...
    沈念sama閱讀 210,978評論 6 490
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件裕偿,死亡現(xiàn)場離奇詭異,居然都是意外死亡痛单,警方通過查閱死者的電腦和手機嘿棘,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 89,954評論 2 384
  • 文/潘曉璐 我一進店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來旭绒,“玉大人鸟妙,你說我怎么就攤上這事』映常” “怎么了重父?”我有些...
    開封第一講書人閱讀 156,623評論 0 345
  • 文/不壞的土叔 我叫張陵,是天一觀的道長忽匈。 經(jīng)常有香客問我房午,道長,這世上最難降的妖魔是什么丹允? 我笑而不...
    開封第一講書人閱讀 56,324評論 1 282
  • 正文 為了忘掉前任郭厌,我火速辦了婚禮,結(jié)果婚禮上雕蔽,老公的妹妹穿的比我還像新娘折柠。我一直安慰自己,他們只是感情好批狐,可當(dāng)我...
    茶點故事閱讀 65,390評論 5 384
  • 文/花漫 我一把揭開白布液走。 她就那樣靜靜地躺著,像睡著了一般。 火紅的嫁衣襯著肌膚如雪缘眶。 梳的紋絲不亂的頭發(fā)上嘱根,一...
    開封第一講書人閱讀 49,741評論 1 289
  • 那天,我揣著相機與錄音巷懈,去河邊找鬼该抒。 笑死,一個胖子當(dāng)著我的面吹牛顶燕,可吹牛的內(nèi)容都是我干的凑保。 我是一名探鬼主播,決...
    沈念sama閱讀 38,892評論 3 405
  • 文/蒼蘭香墨 我猛地睜開眼涌攻,長吁一口氣:“原來是場噩夢啊……” “哼欧引!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起恳谎,我...
    開封第一講書人閱讀 37,655評論 0 266
  • 序言:老撾萬榮一對情侶失蹤芝此,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后因痛,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體婚苹,經(jīng)...
    沈念sama閱讀 44,104評論 1 303
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 36,451評論 2 325
  • 正文 我和宋清朗相戀三年鸵膏,在試婚紗的時候發(fā)現(xiàn)自己被綠了膊升。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 38,569評論 1 340
  • 序言:一個原本活蹦亂跳的男人離奇死亡谭企,死狀恐怖廓译,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情债查,我是刑警寧澤责循,帶...
    沈念sama閱讀 34,254評論 4 328
  • 正文 年R本政府宣布,位于F島的核電站攀操,受9級特大地震影響院仿,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜速和,卻給世界環(huán)境...
    茶點故事閱讀 39,834評論 3 312
  • 文/蒙蒙 一歹垫、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧颠放,春花似錦排惨、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,725評論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽鹿驼。三九已至,卻和暖如春辕宏,著一層夾襖步出監(jiān)牢的瞬間畜晰,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 31,950評論 1 264
  • 我被黑心中介騙來泰國打工瑞筐, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留凄鼻,地道東北人。 一個月前我還...
    沈念sama閱讀 46,260評論 2 360
  • 正文 我出身青樓聚假,卻偏偏與公主長得像块蚌,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子膘格,可洞房花燭夜當(dāng)晚...
    茶點故事閱讀 43,446評論 2 348

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

  • 安裝 npm npm install vuex --save 在一個模塊化的打包系統(tǒng)中峭范,您必須顯式地通過Vue.u...
    蕭玄辭閱讀 2,927評論 0 7
  • vuex是一個狀態(tài)管理模式,通過用戶的actions觸發(fā)事件瘪贱,然后通過mutations去更改數(shù)據(jù)(你也可以說狀態(tài)...
    Ming_Hu閱讀 2,017評論 3 3
  • Vuex是什么纱控? Vuex 是一個專為 Vue.js應(yīng)用程序開發(fā)的狀態(tài)管理模式。它采用集中式存儲管理應(yīng)用的所有組件...
    蕭玄辭閱讀 3,109評論 0 6
  • Vuex 是一個專為 Vue.js 應(yīng)用程序開發(fā)的狀態(tài)管理模式政敢。它采用集中式存儲管理應(yīng)用的所有組件的狀態(tài)其徙,并以相應(yīng)...
    白水螺絲閱讀 4,654評論 7 61
  • vuex 場景重現(xiàn):一個用戶在注冊頁面注冊了手機號碼胚迫,跳轉(zhuǎn)到登錄頁面也想拿到這個手機號碼喷户,你可以通過vue的組件化...
    sunny519111閱讀 8,009評論 4 111