vuex-4.0.0-alpha.1 體驗(yàn)

安裝

npm i -S vuex@4.0.0-alpha.1

or

yarn add vuex@4.0.0-alpha.1

例子

// store.js

import { createStore } from 'vuex'

const subModel = createStore({
    namespaced: true,
    state: {
        target: 'xxx'
    },
    
    mutations: {
        updateTarget(state, newTarget){
            state.target = newTarget
        }
    }
})

export default createStore({
    
    state: {
        
        id: 'xxxx',
        prefix: 'mini',
        name: 'wolf'
    },

    getters: {
        fullName(state){ return `${state.prefix}-${state.name}` }
    },

    mutations: {
         updateName(state, newName){
            state.name = newName
        }
    },
    moduels:{ subModel }
})




// main.js

import { createApp } from 'vue'
import App from './App.vue'
import store from './store.js'

// 創(chuàng)建應(yīng)用
const app = createApp(App)
// 注冊(cè) store
app.use(store)



// page

import { useStore } from 'vuex'
import { computed } from 'vue'

export default {
    setup(){
        // 獲取store實(shí)例
        const store = useStore()
        // 綁定響應(yīng)
        const name = computed(() => store.state.name)
        const fullName = comoputed(() => store.getters.fullName)
        const target = computed(() => store.state.subModel.target )
        return {
            
            name,
            fullName,
            target
        }

    }

}

使用對(duì)比

  • state
// old
{
    computed:{
        name(){ return this.$store.state.name },
        ...mapState('moduleName', [...])
    }

}

// new
{
    
    setup(){

        // 單一值引入
        const name = computed(() => store.state.name )

        // 引入整個(gè)state
        const name = computed( () => store.sate )
    }
    
}
 


  • getter
// old

{
    computed:{
        name(){ return this.$getters.state.name },
        ...mapGetters('moduleName', [...])
    }
}
    
    
// new
{
    
    setup(){

        // 單一值引入
        const name = computed(() => store.getters.name )

        // 引入整個(gè)state
        const name = computed( () => store.getters )
    }
    
}



  • mutation
// old

{
   methods: {
       
       updateName(){
           this.$store.commit('method name', data)
       },
           
      ...mapMutations([
          'methodName'
      ])
       
   }
}


// new

{
    setup(){

        const updateName = newName => store.commit("name", newName)
        
    }
}
  • action
// old
{
    methods:{
        load(){
            this.$store.dispatch('methodName', data)
        },
        ...mapActions(['methodName'])
    }
}

// new

{
    setup(){
        const load = () => store.dispath('methodName', data)
    }
}

hack

  • getter observe
// 將computed 放在 getter中
{
    
    state:{ name: 'coco' },
    getters:{
        
        observeName(state){
            return computed(() => state.name)
        }
        
    }
    
}

// page
{
    
    setup(){
        
        return {
            name: store.state.name // 不響應(yīng)值變化
            observeName: store.getters.observeName // 響應(yīng)值變化
        }
    }
    
}

通過 getter 返回包裝后值庄撮,減少組件內(nèi)的 computed 包裝

  • state data-prop

{
    setup(){
        
        return {
            
            name: store.state.name,
            nameCopy: store.state.name,
            staticName: 'xxx'

        }
        
    },
    
    template:`
        
        <h1> {{ name }} </h1>
        <h1> {{ nameCopy }} </h1>
        <input v-model='name' />

        <h1> {{ staticName }} </h1>
        <input v-model='staticName' />

    `
}

純值不能作為 v-model 綁定值, 隨著 input 的輸入, name 響應(yīng)值變化巡扇, nameCopy 未響應(yīng),

  • state ref
{
    state: {
        refName: ref('name')
    }
}


// page
{
    setup(){
        const store = useStore()
        
        return {
            refName: store.state.refName
        }
    }刀闷,
   template:`
        
        <input v-modle='refName'></input>

    `
}

直接使用 ref 作為state, 類似實(shí)現(xiàn)全局變量, 不推薦這種使用方式 直接屏蔽單項(xiàng)數(shù)據(jù)流模式。

總結(jié)

新的vuex 基礎(chǔ)使用及api 沒要太大變化, 調(diào)用方式更靈活. 但在當(dāng)前的新的vue 版本下, vuex 存在的意義不大.

對(duì)于中小項(xiàng)目, 完全可以依靠 vue 實(shí)現(xiàn)自定義的全局狀態(tài)管理工具.

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末吨枉,一起剝皮案震驚了整個(gè)濱河市属提,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌堪滨,老刑警劉巖发笔,帶你破解...
    沈念sama閱讀 218,682評(píng)論 6 507
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場(chǎng)離奇詭異,居然都是意外死亡,警方通過查閱死者的電腦和手機(jī)苞冯,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,277評(píng)論 3 395
  • 文/潘曉璐 我一進(jìn)店門鳍烁,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人,你說我怎么就攤上這事】闯桑” “怎么了?”我有些...
    開封第一講書人閱讀 165,083評(píng)論 0 355
  • 文/不壞的土叔 我叫張陵,是天一觀的道長(zhǎng)赢织。 經(jīng)常有香客問我茧吊,道長(zhǎng)话速,這世上最難降的妖魔是什么乳讥? 我笑而不...
    開封第一講書人閱讀 58,763評(píng)論 1 295
  • 正文 為了忘掉前任白指,我火速辦了婚禮,結(jié)果婚禮上仰楚,老公的妹妹穿的比我還像新娘侨嘀。我一直安慰自己,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,785評(píng)論 6 392
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著捉貌,像睡著了一般支鸡。 火紅的嫁衣襯著肌膚如雪冬念。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 51,624評(píng)論 1 305
  • 那天牧挣,我揣著相機(jī)與錄音急前,去河邊找鬼。 笑死瀑构,一個(gè)胖子當(dāng)著我的面吹牛裆针,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播寺晌,決...
    沈念sama閱讀 40,358評(píng)論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼世吨,長(zhǎng)吁一口氣:“原來是場(chǎng)噩夢(mèng)啊……” “哼!你這毒婦竟也來了呻征?” 一聲冷哼從身側(cè)響起耘婚,我...
    開封第一講書人閱讀 39,261評(píng)論 0 276
  • 序言:老撾萬榮一對(duì)情侶失蹤,失蹤者是張志新(化名)和其女友劉穎陆赋,沒想到半個(gè)月后沐祷,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 45,722評(píng)論 1 315
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡攒岛,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,900評(píng)論 3 336
  • 正文 我和宋清朗相戀三年戈轿,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片阵子。...
    茶點(diǎn)故事閱讀 40,030評(píng)論 1 350
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡思杯,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出挠进,到底是詐尸還是另有隱情色乾,我是刑警寧澤,帶...
    沈念sama閱讀 35,737評(píng)論 5 346
  • 正文 年R本政府宣布领突,位于F島的核電站暖璧,受9級(jí)特大地震影響,放射性物質(zhì)發(fā)生泄漏君旦。R本人自食惡果不足惜澎办,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,360評(píng)論 3 330
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望金砍。 院中可真熱鬧局蚀,春花似錦、人聲如沸恕稠。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,941評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)鹅巍。三九已至千扶,卻和暖如春料祠,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背澎羞。 一陣腳步聲響...
    開封第一講書人閱讀 33,057評(píng)論 1 270
  • 我被黑心中介騙來泰國(guó)打工髓绽, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人妆绞。 一個(gè)月前我還...
    沈念sama閱讀 48,237評(píng)論 3 371
  • 正文 我出身青樓顺呕,卻偏偏與公主長(zhǎng)得像,于是被迫代替她去往敵國(guó)和親摆碉。 傳聞我的和親對(duì)象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,976評(píng)論 2 355

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

  • ### store 1. Vue 組件中獲得 Vuex 狀態(tài) ```js //方式一 全局引入單例類 // 創(chuàng)建一...
    蕓豆_6a86閱讀 731評(píng)論 0 3
  • Vuex 概念篇 Vuex 是什么脓豪? Vuex 是一個(gè)專為 Vue.js 應(yīng)用程序開發(fā)的狀態(tài)管理模式巷帝。它采用集中式...
    Junting閱讀 3,082評(píng)論 0 43
  • 安裝 npm npm install vuex --save 在一個(gè)模塊化的打包系統(tǒng)中,您必須顯式地通過Vue.u...
    蕭玄辭閱讀 2,938評(píng)論 0 7
  • Vuex Vuex是一個(gè)專門為Vue.js應(yīng)用所設(shè)計(jì)的集中式狀態(tài)管理架構(gòu)扫夜,它借鑒了Flux和Redux的設(shè)計(jì)思想楞泼,...
    JunChow520閱讀 1,570評(píng)論 2 0
  • 習(xí)慣養(yǎng)成很容易,戒掉卻很難s源场6槔! 什么是Vuex颗味? Vuex 是一個(gè)專為 Vue.js 應(yīng)用程序開發(fā)的狀態(tài)管理模式...
    前端又又閱讀 2,775評(píng)論 0 1