簡(jiǎn)單的vuex 的使用案例筆記
1、 npm install vuex
2、 在src 下 新建文件夾 store (為什么是這個(gè)單詞,vuex 是用來(lái)狀態(tài)管理的,用儲(chǔ)存一些組件的狀態(tài),取存貯,倉(cāng)庫(kù)之意),store 文件下 新建文件 index.js (為什么是index.js? 在導(dǎo)入的時(shí)候,會(huì)第一選擇這個(gè)叫index的文件)
3、 index.js import 導(dǎo)入 vue 和vuex (import 是es6 的語(yǔ)法, es5 是 require), 代碼如下:
這里的demo 是一個(gè) 改變 app 的模式 的一個(gè)appellation ,選擇是 夜間模式還是白天模式
import Vue from 'vue'
import Vuex from 'vuex'
Vue.use(Vuex)
export default new Vuex.Store({
state: {
night: true,
text: '白天',
className: 'morning'
},
mutations: {
increment (state) {
state.night = !state.night;
state.text = state.night === true ? '晚上' : '白天';
state.className = state.night === true ? 'night' : 'morning';
}
}
})
4、 main.js import 這個(gè)index.js 代碼如下:
// The Vue build version to load with the `import` command
// (runtime-only or standalone) has been set in webpack.base.conf with an alias.
import Vue from 'vue'
import App from './App'
import router from './router'
import store from './store' // 會(huì)找index.js
/* eslint-disable no-new */
new Vue({
el: '#app',
router,
store, // 注入根組件,其他子組件 都可以引用
template: '<App/>',
components: { App }
})
5、使用vuex 的狀態(tài)
組件1:
dom :
<div class="header" :class="model">
js
computed: {
model() {
return this.$store.state.className // 是ninght 還是 morning
}
},
注意:
:class="model" 這個(gè)class 可以綁定一個(gè)方法傳參數(shù),可以直接用 js 表達(dá)式,可以綁定一個(gè)計(jì)算屬性
組件2:
dom:
<div class='modal' @click="changeModel">
<div class="avatar">
<img src="../../assets/img/logo.png" width="18" height="18">
</div>
<div class="name">
{{currentModel}}
</div>
<!-- vuex 相當(dāng)于全局注入 vuex 然后取這里面的值 -->
</div>
js:
computed: {
currentModel () {
return this.$store.state.text
}
},
methods: {
changeModel () {
// document.body.className='night'
this.$store.commit('increment')
}
}
注意:
js 中的 currentModel 和 dom 中的 {{ currentModel }} 是一個(gè),和 :class 可以跟表達(dá)方法一樣 ,可以跟變量 ,表達(dá)方法 ,表達(dá)式 ( 這里靈活的模版方法,回頭查看下源碼,然后補(bǔ)充這的說(shuō)明, vue模版為何如此強(qiáng)大?。?/p>
點(diǎn)擊事件,觸發(fā)方法 changeModel ,changeModel 觸發(fā) mutation 的方法,顯示改變 值 ,這個(gè)是固定的語(yǔ)法, this.$store.commit('increment');
increment 可以在定義的時(shí)候,設(shè)置參數(shù),傳參數(shù), this.$store.commit('increment', 'argumnet') , 在 mutation 里面 increment (state , arg) { .. = arg; ....};
截圖如下:

默認(rèn)方式:
如上圖顯示。默認(rèn)的是,白天的模式,className 是 morning;
點(diǎn)擊事件觸發(fā)模式;

再次點(diǎn)擊的時(shí)候,可以在改回來(lái),這個(gè)竅門(mén),就是 index.js 里面,increment 對(duì) night 的變量 取 對(duì) 的一個(gè)邏輯方法。跟jq 里面的 toggle,類(lèi)似

結(jié)束語(yǔ):
簡(jiǎn)單的vuex 的案例 ,做個(gè)筆記。希望對(duì)大家有所幫助,如果大家有任何疑問(wèn)請(qǐng)給我留言,小編會(huì)及時(shí)回復(fù)大家的。在此也非常感謝大家對(duì)腳本之家網(wǎng)站的支持!
相關(guān)文章
vue項(xiàng)目引入百度地圖BMapGL鼠標(biāo)繪制和BMap輔助工具
這篇文章主要為大家介紹了vue項(xiàng)目引入百度地圖BMapGL鼠標(biāo)繪制和BMap輔助工具的踩坑分析,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-02-02
在vue項(xiàng)目中使用Jquery-contextmenu插件的步驟講解
今天小編就為大家分享一篇關(guān)于在vue項(xiàng)目中使用Jquery-contextmenu插件的步驟講解,小編覺(jué)得內(nèi)容挺不錯(cuò)的,現(xiàn)在分享給大家,具有很好的參考價(jià)值,需要的朋友一起跟隨小編來(lái)看看吧2019-01-01
Vue v-model相關(guān)知識(shí)總結(jié)
這篇文章主要介紹了Vue ​v-model相關(guān)知識(shí)總結(jié),幫助大家更好的理解和學(xué)習(xí)使用vue框架,感興趣的朋友可以了解下2021-01-01
vue+iview+less+echarts實(shí)戰(zhàn)項(xiàng)目總結(jié)
本篇文章是作者通過(guò)學(xué)習(xí)vue+iview+less+echarts制作一個(gè)小系統(tǒng)后,做的心得以及遇到的坑的總結(jié),值得大家學(xué)習(xí)參考。2018-02-02

