vuex一些易混淆概念

vuex 是針對 vue 而設(shè)計(jì)的狀態(tài)管理擴(kuò)展雇锡,你可以理解為 react 中的 Redux,和 flux 的衍生物僚焦。本文并不是詳細(xì)教程锰提,是介紹使用 vuex 中,一些讓人迷惑的點(diǎn)的文章,因?yàn)榇蠖鄶?shù)人為了快速使用 vuex立肘,而選擇看視頻或者不求甚解地閱讀文檔边坤,但是當(dāng)深入做項(xiàng)目時,難免會有幾個點(diǎn)會不禁要問自己幾個為什么:

1. 使用 dispatch 還是 commit 谅年?

在vue 組件中(Child.vue)茧痒,我們會給定一個方法,通過這個方法使用 dispatch 觸發(fā) action 從而提交相應(yīng)的 mutation融蹂,舉個栗子:

methods: {
methods: {
    show(id) {
        if(id == 1) {
            this.$store.dispatch('showA');
        } else {
            this.$store.dispatch('hideA');
        }
    }
}
methods: {
    show(id) {
        if(id == 1) {
            this.$store.commit('SHOW_A'); // 使用大寫是一種推薦命名寫法旺订,具體看文檔
        } else {
            this.$store.commit('HIDE_A');
        }
    }
}

這兩者,在處理簡單的狀態(tài)變化時殿较,沒有區(qū)別耸峭,當(dāng)需要異步桩蓉,或者其他復(fù)雜操作時淋纲,dispatch 就更加適用,因?yàn)?mutation 是同步改變狀態(tài)的院究,無法執(zhí)行異步操作洽瞬,而 dispatch 的含義是“先觸發(fā)action”,經(jīng)過 action 你可以執(zhí)行異步操作业汰,actionA 和 actionB 之間的先后順序等等伙窃,而在組件中直接 commit 無法執(zhí)行一系列復(fù)雜操作。

2. 向 dispatch 和 commit 傳遞參數(shù):

在寫項(xiàng)目的時候样漆,由于之前寫項(xiàng)目空檔時間較長为障,很多基礎(chǔ)知識都給忽略了,在給 dispatch 傳遞參數(shù)的時候放祟,直接就用形參的形式傳遞了參數(shù):

this.$store.dispatch('showA', id);

雖然結(jié)果證明可以生效鳍怨,因?yàn)榈讓影b的時候就是將第二個參數(shù)以對象形式傳遞的,但是當(dāng)多個參數(shù)的時候不確定會不會出錯跪妥,并沒有試驗(yàn)鞋喇,這里只給出官方文檔的寫法,畢竟用了這個框架眉撵,就按照標(biāo)準(zhǔn)來:

// 以載荷形式分發(fā)
store.dispatch('incrementAsync', {
  amount: 10
})
// 以對象形式分發(fā)
store.dispatch({
  type: 'incrementAsync',
  amount: 10
})

3. 如果一個組件侦香,多次在其他組件中出現(xiàn),是否每次都要 import 引入一遍呢纽疟?

當(dāng)然可以每次都引入罐韩,不過還有一種更簡單的方法,就是將這個組件用 vue 擴(kuò)展的方式封裝污朽,然后就可以像使用 vuex 或者 vue-router 一樣散吵,在每個組件中直接使用了。

  1. 封裝擴(kuò)展
    首先寫一個組件,不用導(dǎo)出組件错蝴,直接寫結(jié)構(gòu)和樣式即可:
<template>
    <div class="loading">
        <div class="loading-inner">
            <div class="ball-spin-fade-loader">
              <div></div>
              <div></div>
              <div></div>
              <div></div>
              <div></div>
              <div></div>
              <div></div>
              <div></div>
            </div>
        </div>
    </div>
</template>
<style scoped>
    .loading{
        position: fixed;
        z-index: 1000;
        width:100%;
        height:90px;
    }
    .loading-inner{
        display:flex;
        display: flex;
        height: 100px;
        align-items: center;
        justify-content: center;
    }
    @-webkit-keyframes ball-spin-fade-loader {
      50% {
        opacity: 0.3;
        -webkit-transform: scale(0.4);
                transform: scale(0.4); }

      100% {
        opacity: 1;
        -webkit-transform: scale(1);
                transform: scale(1); } }

    @keyframes ball-spin-fade-loader {
      50% {
        opacity: 0.3;
        -webkit-transform: scale(0.4);
                transform: scale(0.4); }

      100% {
        opacity: 1;
        -webkit-transform: scale(1);
                transform: scale(1); } }

    .ball-spin-fade-loader {
      position: relative; }
      .ball-spin-fade-loader > div:nth-child(1) {
        top: 25px;
        left: 0;
        -webkit-animation: ball-spin-fade-loader 1s 0s infinite linear;
                animation: ball-spin-fade-loader 1s 0s infinite linear; }
      .ball-spin-fade-loader > div:nth-child(2) {
        top: 17.04545px;
        left: 17.04545px;
        -webkit-animation: ball-spin-fade-loader 1s 0.12s infinite linear;
                animation: ball-spin-fade-loader 1s 0.12s infinite linear; }
      .ball-spin-fade-loader > div:nth-child(3) {
        top: 0;
        left: 25px;
        -webkit-animation: ball-spin-fade-loader 1s 0.24s infinite linear;
                animation: ball-spin-fade-loader 1s 0.24s infinite linear; }
      .ball-spin-fade-loader > div:nth-child(4) {
        top: -17.04545px;
        left: 17.04545px;
        -webkit-animation: ball-spin-fade-loader 1s 0.36s infinite linear;
                animation: ball-spin-fade-loader 1s 0.36s infinite linear; }
      .ball-spin-fade-loader > div:nth-child(5) {
        top: -25px;
        left: 0;
        -webkit-animation: ball-spin-fade-loader 1s 0.48s infinite linear;
                animation: ball-spin-fade-loader 1s 0.48s infinite linear; }
      .ball-spin-fade-loader > div:nth-child(6) {
        top: -17.04545px;
        left: -17.04545px;
        -webkit-animation: ball-spin-fade-loader 1s 0.6s infinite linear;
                animation: ball-spin-fade-loader 1s 0.6s infinite linear; }
      .ball-spin-fade-loader > div:nth-child(7) {
        top: 0;
        left: -25px;
        -webkit-animation: ball-spin-fade-loader 1s 0.72s infinite linear;
                animation: ball-spin-fade-loader 1s 0.72s infinite linear; }
      .ball-spin-fade-loader > div:nth-child(8) {
        top: 17.04545px;
        left: -17.04545px;
        -webkit-animation: ball-spin-fade-loader 1s 0.84s infinite linear;
                animation: ball-spin-fade-loader 1s 0.84s infinite linear; }
      .ball-spin-fade-loader > div {
        background-color: #5477b2;
        width: 15px;
        height: 15px;
        border-radius: 100%;
        margin: 2px;
        -webkit-animation-fill-mode: both;
                animation-fill-mode: both;
        position: absolute; }
</style>
  1. 為了將其封裝為擴(kuò)展洲愤,需要用到node組件的寫法,即建立個入口文件顷锰,將組件導(dǎo)出柬赐,為此,結(jié)構(gòu)目錄長成這樣:


  2. ok官紫,現(xiàn)在來寫index入口文件:
const LoadingComponent = require('./Loading.vue')
const loading = {
  install: function(Vue) {
    Vue.component('loading', LoadingComponent)
  }
}
module.exports = loading

require 是引入剛才寫的組件肛宋,loading對象是封裝 vue 擴(kuò)展的寫法,具體的可以參考文檔束世,install 屬性就是為了封裝擴(kuò)展而存在的酝陈,而 module.exports 是導(dǎo)出組件,遵循的是 commonJS 規(guī)范毁涉,想具體了解可以看看 nodeJS入門沉帮,了解下 nodeJS 組件的寫法,理解這個就簡單了贫堰。

  1. 接下來穆壕,我們就可以用這個封裝好的 loading 效果擴(kuò)展組件了:
// main.js
import Loading from './components/Loading' // 引入Loading.vue
Vue.use(Loading);  // 使用擴(kuò)展
  1. 在任何組件中,都可以直接使用 loading 擴(kuò)展其屏,而不用 import 引入組件了:
// App.vue
<loading v-if="loading"></loading>

4. import 和 require 的使用場景:

由于 webpack 是模塊加載器喇勋,所以在寫 vue 的時候,使用 import 和 require 都可以偎行,import 更多的是引入功能組件川背,并且用法靈活,而 require 就是引入文件蛤袒。

  • 兩者的用法其實(shí)取決于組件的封裝形式熄云;
  • 還有一種特殊情況,就是引入靜態(tài)資源汗盘,例如CSS 或者 圖片等皱碘,這時候就要用 require;
    兩者是兩種概念隐孽,放在一起比較難免不妥癌椿,只是有時候會混淆,建議看下 ES 6 中菱阵,import 的相關(guān)知識踢俄,就能看出和 require 的使用區(qū)別了。

雖然文章沒啥技術(shù)含量晴及,不過轉(zhuǎn)載請注明出處都办,謝謝啦

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市,隨后出現(xiàn)的幾起案子琳钉,更是在濱河造成了極大的恐慌势木,老刑警劉巖,帶你破解...
    沈念sama閱讀 206,126評論 6 481
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件歌懒,死亡現(xiàn)場離奇詭異啦桌,居然都是意外死亡,警方通過查閱死者的電腦和手機(jī)及皂,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 88,254評論 2 382
  • 文/潘曉璐 我一進(jìn)店門甫男,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人验烧,你說我怎么就攤上這事板驳。” “怎么了碍拆?”我有些...
    開封第一講書人閱讀 152,445評論 0 341
  • 文/不壞的土叔 我叫張陵若治,是天一觀的道長。 經(jīng)常有香客問我倔监,道長直砂,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 55,185評論 1 278
  • 正文 為了忘掉前任浩习,我火速辦了婚禮,結(jié)果婚禮上济丘,老公的妹妹穿的比我還像新娘谱秽。我一直安慰自己,他們只是感情好摹迷,可當(dāng)我...
    茶點(diǎn)故事閱讀 64,178評論 5 371
  • 文/花漫 我一把揭開白布疟赊。 她就那樣靜靜地躺著,像睡著了一般峡碉。 火紅的嫁衣襯著肌膚如雪近哟。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 48,970評論 1 284
  • 那天鲫寄,我揣著相機(jī)與錄音吉执,去河邊找鬼。 笑死地来,一個胖子當(dāng)著我的面吹牛戳玫,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播未斑,決...
    沈念sama閱讀 38,276評論 3 399
  • 文/蒼蘭香墨 我猛地睜開眼咕宿,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起府阀,我...
    開封第一講書人閱讀 36,927評論 0 259
  • 序言:老撾萬榮一對情侶失蹤缆镣,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后试浙,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體费就,經(jīng)...
    沈念sama閱讀 43,400評論 1 300
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 35,883評論 2 323
  • 正文 我和宋清朗相戀三年川队,在試婚紗的時候發(fā)現(xiàn)自己被綠了力细。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 37,997評論 1 333
  • 序言:一個原本活蹦亂跳的男人離奇死亡固额,死狀恐怖眠蚂,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情斗躏,我是刑警寧澤逝慧,帶...
    沈念sama閱讀 33,646評論 4 322
  • 正文 年R本政府宣布,位于F島的核電站啄糙,受9級特大地震影響笛臣,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜隧饼,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 39,213評論 3 307
  • 文/蒙蒙 一沈堡、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧燕雁,春花似錦诞丽、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,204評論 0 19
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至捏浊,卻和暖如春懂衩,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背金踪。 一陣腳步聲響...
    開封第一講書人閱讀 31,423評論 1 260
  • 我被黑心中介騙來泰國打工浊洞, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人热康。 一個月前我還...
    沈念sama閱讀 45,423評論 2 352
  • 正文 我出身青樓沛申,卻偏偏與公主長得像,于是被迫代替她去往敵國和親姐军。 傳聞我的和親對象是個殘疾皇子铁材,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 42,722評論 2 345

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

  • afinalAfinal是一個android的ioc尖淘,orm框架 https://github.com/yangf...
    passiontim閱讀 15,399評論 2 45
  • 什么是過往?一幕幕回放 是曾經(jīng)干癟的錢囊著觉,但斗志昂揚(yáng) 是與時運(yùn)的對抗 是入錯的行 是鬼門關(guān)走一趟村生,驚出一身冷汗 是...
    王家子弟閱讀 238評論 2 4
  • 二十分鐘前我給無戒老師連續(xù)發(fā)了三條消息: “老師趁桃,”“美女老師,”“我要哭R薷搿卫病!” 后面還想說一句:“日更讓我好痛苦...
    JaryYang閱讀 617評論 43 31
  • 我理想的早晨是這樣度過的:六點(diǎn)起床,喝一杯溫的蜂蜜水典徘,清潔腸道之后看天氣或慢跑20分鐘或在家里做20分鐘瑜伽蟀苛。洗個...
    茉莉大大閱讀 165評論 0 0