溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶服務(wù)條款》

簡(jiǎn)單的vuex 的使用案例筆記

發(fā)布時(shí)間:2020-09-28 21:26:13 來源:腳本之家 閱讀:126 作者:adouwt 欄目:web開發(fā)

1、 npm install vuex

2、 在src 下 新建文件夾 store (為什么是這個(gè)單詞,vuex 是用來狀態(tài)管理的,用儲(chǔ)存一些組件的狀態(tài),取存貯,倉庫之意),store 文件下 新建文件 index.js  (為什么是index.js? 在導(dǎo)入的時(shí)候,會(huì)第一選擇這個(gè)叫index的文件)

3、 index.js import 導(dǎo)入 vue 和vuex (import 是es6 的語法, 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ǔ)充這的說明, vue模版為何如此強(qiáng)大?。?/p>

點(diǎn)擊事件,觸發(fā)方法 changeModel ,changeModel 觸發(fā) mutation 的方法,顯示改變 值 ,這個(gè)是固定的語法, this.$store.commit('increment');

increment 可以在定義的時(shí)候,設(shè)置參數(shù),傳參數(shù), this.$store.commit('increment', 'argumnet') , 在 mutation 里面  increment (state , arg) { .. = arg; ....};

截圖如下:

簡(jiǎn)單的vuex 的使用案例筆記

默認(rèn)方式:

如上圖顯示。默認(rèn)的是,白天的模式,className 是 morning;

  點(diǎn)擊事件觸發(fā)模式;

簡(jiǎn)單的vuex 的使用案例筆記

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

簡(jiǎn)單的vuex 的使用案例筆記

結(jié)束語:

簡(jiǎn)單的vuex 的案例 ,做個(gè)筆記。希望對(duì)大家有所幫助,如果大家有任何疑問請(qǐng)給我留言,小編會(huì)及時(shí)回復(fù)大家的。在此也非常感謝大家對(duì)億速云網(wǎng)站的支持!

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI