vuex(二)

之前總結(jié)了一些vuex的基礎(chǔ)性知識慕匠,只是通過一些簡單的動作來改變 store.js 中的數(shù)據(jù)對象杭朱。這是完全無法滿足工作需求的阅仔,還需要學(xué)習(xí)一些流程判斷。
一弧械、比如說我現(xiàn)在有這么個需求八酒,當(dāng) count < 5 的時候,就停止 count-- 刃唐。這就需要用到 actions

**[actions](https://link.jianshu.com/?t=https%3A%2F%2Fvuex.vuejs.org%2Fzh-cn%2Factions.html)** 定義要執(zhí)行的動作羞迷,如流程的判斷、異步請求

在 store.js 內(nèi)的 actions 中

// 定義 actions 画饥,要執(zhí)行的動作衔瓮,如流程的判斷、異步請求
const actions ={
    increment({commit,state}){
        commit('increment') 
    },
    decrement({ commit, state }) {
        // **通過動作改變的數(shù)據(jù)荒澡,在此處來做判斷是否提交**
        if (state.count > 5) {
            commit('decrement')
        }
    }
}

運行項目


4279446-ef01bbfaa66c55f6.gif
二报辱、通過 actions 模擬異步請求
1. 先在 App.vue 中定義好事件
<template>
  <div id="app">
    <button @click="increment">增加</button>
    <button @click="decrement">減少</button>
    //異步請求事件
    <button @click="incrementAsync">異步增加</button>
    <h1>{{count}}</h1>
  </div>
</template>

<script>
import {mapGetters,mapActions} from 'vuex'
export default {
  name: 'app',
  computed:mapGetters([
    'count'
  ]),
  methods:mapActions([
    'increment',
    'decrement',
    'incrementAsync'
  ])
}
</script>

2. 在 store.js 內(nèi)的 actions 中添加 異步 Promise 事件

// 定義 actions ,要執(zhí)行的動作单山,如流程的判斷、異步請求
const actions ={
    increment({commit,state}){
        commit('increment') 
    },
    decrement({ commit, state }) {
        // **通過動作改變的數(shù)據(jù)幅疼,在此處來做判斷是否提交**
        if (state.count > 5) {
            commit('decrement')
        }
    },
    incrementAsync({commit,state}){
        // 模擬異步操作
        var a = new Promise((resolve,reject) => {
            setTimeout(() => {
                resolve();
            }, 3000);
        })
        // 3 秒之后提交一次 increment 米奸,也就是執(zhí)行一次 increment 
        a.then(() => {
            commit('increment')
        }).catch(() => {
            console.log('異步操作失敗');
        })
    }
}
1.gif
三、獲取數(shù)據(jù)狀態(tài)

假如我們需要知道數(shù)據(jù)的奇偶數(shù)爽篷,那么就需要在 getters 中來判斷悴晰。

getters 中可以獲取經(jīng)過處理后的數(shù)據(jù),從而來判斷狀態(tài)

在 store.js 的 getters 中加入判斷奇偶數(shù)的方法

var getters={
    count(state){
        return state.count
    },
    EvenOrOdd(state){
        return state.count%2==0 ? '偶數(shù)' : '奇數(shù)'
    }
}

在 App.vue 中加入

<template>
  <div id="app">
    <button @click="increment">增加</button>
    <button @click="decrement">減少</button>
    <button @click="incrementAsync">異步增加</button>
    <h1>{{count}}</h1>
    <!-- 判斷奇偶數(shù)的方法  這種寫法它會自動調(diào)用 EvenOrOdd 方法中的返回值,拿到的是個屬性 -->
    <h1>{{EvenOrOdd}}</h1>
  </div>
</template>

<script>
import {mapGetters,mapActions} from 'vuex'
export default {
  name: 'app',
  computed:mapGetters([
    // 判斷奇偶數(shù)的方法
    'EvenOrOdd',
    'count'
  ]),
  methods:mapActions([
    'increment',
    'decrement',
    'incrementAsync'
  ])
}
</script>

4279446-828bb67e550e3114.gif
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末铡溪,一起剝皮案震驚了整個濱河市漂辐,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌棕硫,老刑警劉巖髓涯,帶你破解...
    沈念sama閱讀 218,525評論 6 507
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異哈扮,居然都是意外死亡纬纪,警方通過查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,203評論 3 395
  • 文/潘曉璐 我一進(jìn)店門滑肉,熙熙樓的掌柜王于貴愁眉苦臉地迎上來包各,“玉大人,你說我怎么就攤上這事靶庙∥食” “怎么了?”我有些...
    開封第一講書人閱讀 164,862評論 0 354
  • 文/不壞的土叔 我叫張陵六荒,是天一觀的道長护姆。 經(jīng)常有香客問我,道長恬吕,這世上最難降的妖魔是什么签则? 我笑而不...
    開封第一講書人閱讀 58,728評論 1 294
  • 正文 為了忘掉前任,我火速辦了婚禮铐料,結(jié)果婚禮上渐裂,老公的妹妹穿的比我還像新娘。我一直安慰自己钠惩,他們只是感情好柒凉,可當(dāng)我...
    茶點故事閱讀 67,743評論 6 392
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著篓跛,像睡著了一般膝捞。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上愧沟,一...
    開封第一講書人閱讀 51,590評論 1 305
  • 那天蔬咬,我揣著相機(jī)與錄音,去河邊找鬼沐寺。 笑死林艘,一個胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的混坞。 我是一名探鬼主播狐援,決...
    沈念sama閱讀 40,330評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼钢坦,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了啥酱?” 一聲冷哼從身側(cè)響起爹凹,我...
    開封第一講書人閱讀 39,244評論 0 276
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎镶殷,沒想到半個月后禾酱,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 45,693評論 1 314
  • 正文 獨居荒郊野嶺守林人離奇死亡批钠,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 37,885評論 3 336
  • 正文 我和宋清朗相戀三年宇植,在試婚紗的時候發(fā)現(xiàn)自己被綠了。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片埋心。...
    茶點故事閱讀 40,001評論 1 348
  • 序言:一個原本活蹦亂跳的男人離奇死亡指郁,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出拷呆,到底是詐尸還是另有隱情闲坎,我是刑警寧澤,帶...
    沈念sama閱讀 35,723評論 5 346
  • 正文 年R本政府宣布茬斧,位于F島的核電站腰懂,受9級特大地震影響,放射性物質(zhì)發(fā)生泄漏项秉。R本人自食惡果不足惜绣溜,卻給世界環(huán)境...
    茶點故事閱讀 41,343評論 3 330
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望娄蔼。 院中可真熱鬧怖喻,春花似錦、人聲如沸岁诉。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,919評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽涕癣。三九已至哗蜈,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間坠韩,已是汗流浹背距潘。 一陣腳步聲響...
    開封第一講書人閱讀 33,042評論 1 270
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機(jī)就差點兒被人妖公主榨干…… 1. 我叫王不留只搁,地道東北人绽昼。 一個月前我還...
    沈念sama閱讀 48,191評論 3 370
  • 正文 我出身青樓,卻偏偏與公主長得像须蜗,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點故事閱讀 44,955評論 2 355

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

  • 安裝 npm npm install vuex --save 在一個模塊化的打包系統(tǒng)中明肮,您必須顯式地通過Vue.u...
    蕭玄辭閱讀 2,938評論 0 7
  • vuex 場景重現(xiàn):一個用戶在注冊頁面注冊了手機(jī)號碼菱农,跳轉(zhuǎn)到登錄頁面也想拿到這個手機(jī)號碼,你可以通過vue的組件化...
    sunny519111閱讀 8,015評論 4 111
  • 姓名:岳沁 學(xué)號:17101223458 轉(zhuǎn)載自:http://blog.csdn.net/h5_queensty...
    丘之心閱讀 2,146評論 0 1
  • Yesterday we managed to crack the UniquePaths issue via D...
    DrunkPian0閱讀 133評論 0 0
  • 言多語失 你失態(tài)了
    幽谷DNWF閱讀 129評論 0 0