欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

對(duì)vuex中store和$store的區(qū)別說(shuō)明

 更新時(shí)間:2020年07月24日 09:48:49   作者:行走的碎道  
這篇文章主要介紹了對(duì)vuex中store和$store的區(qū)別說(shuō)明,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧

這里寫(xiě)自定義目錄標(biāo)題

<router-link to="/login">{{ $store.state.userName }}</router-link>
<router-link to="/login">{{ store.state.userName }}</router-link>
<router-link to="/login">{{ this.store.state.userName }}</router-link>
<router-link to="/login">{{ this.$store.state.userName }}</router-link>

1、$store 是掛載在 Vue 實(shí)例上的(即Vue.prototype),而組件也其實(shí)是一個(gè)Vue實(shí)例(所有組件都是實(shí)例,每個(gè)組件都是一個(gè)vue實(shí)例,所有的 Vue 組件都是 Vue 實(shí)例:一個(gè) Vue 應(yīng)用由一個(gè)通過(guò) new Vue 創(chuàng)建的根 Vue 實(shí)例,以及可選的嵌套的、可復(fù)用的組件樹(shù)組成,也就是說(shuō):組件放到根組件中使用)在組件中可使用 this 訪問(wèn)原型上的屬性,template 擁有組件實(shí)例的上下文,可直接通過(guò) {{ KaTeX parse error: Expected 'EOF', got '}' at position 22: …state.userName }̲} 訪問(wèn),等價(jià)于 script…store.state.userName。

2、store是掛載到vue上,為vue的根實(shí)例;store引入后被注入到vue上,成為vue的原型屬性,所以通過(guò)store是掛載到vue上,為vue的根實(shí)例;store引入后被注入到vue上,成為vue的原型屬性,所以通過(guò)store是掛載到vue上,為vue的根實(shí)例;store引入后被注入到vue上,成為vue的原型屬性,所以通過(guò)store.state和this.$store.state可以訪問(wèn)。

補(bǔ)充知識(shí):vue 的狀態(tài)管理vuex中store的使用

一、狀態(tài)管理(vuex)簡(jiǎn)介

vuex是專為vue.js應(yīng)用程序開(kāi)發(fā)的狀態(tài)管理模式。它采用集中存儲(chǔ)管理應(yīng)用的所有組件的狀態(tài),并以相應(yīng)的規(guī)則保證狀態(tài)以一種可預(yù)測(cè)的方式發(fā)生變化。vuex也集成刀vue的官方調(diào)試工具devtools extension,提供了諸如零配置的time-travel調(diào)試、狀態(tài)快照導(dǎo)入導(dǎo)出等高級(jí)調(diào)試功能。

二、狀態(tài)管理核心

狀態(tài)管理有5個(gè)核心,分別是state、getter、mutation、action以及module。分別簡(jiǎn)單的介紹一下它們:

開(kāi)始使用vuex,新建一個(gè) sotre文件夾,分開(kāi)維護(hù) actions mutations getters

1、state

state為單一狀態(tài)樹(shù),在state中需要定義我們所需要管理的數(shù)組、對(duì)象、字符串等等,只有在這里定義了,在vue.js的組件中才能獲取你定義的這個(gè)對(duì)象的狀態(tài)。

在store/index.js文件中新建vuex 的store實(shí)例

*as的意思是 導(dǎo)入這個(gè)文件里面的所有內(nèi)容,就不用一個(gè)個(gè)實(shí)例來(lái)導(dǎo)入了。

import Vue from 'vue'
import Vuex from 'vuex'
import * as getters from './getters' // 導(dǎo)入響應(yīng)的模塊,*相當(dāng)于引入了這個(gè)組件下所有導(dǎo)出的事例
import * as actions from './actions'
import * as mutations from './mutations'
 
Vue.use(Vuex)
// 首先聲明一個(gè)需要全局維護(hù)的狀態(tài) state,比如 我這里舉例的resturantName
const state = {
  resturantName: '飛歌餐館' // 默認(rèn)值
  // id: xxx 如果還有全局狀態(tài)也可以在這里添加
  // name:xxx
}
// 注冊(cè)上面引入的各大模塊
const store = new Vuex.Store({
  state,  // 共同維護(hù)的一個(gè)狀態(tài),state里面可以是很多個(gè)全局狀態(tài)
  getters, // 獲取數(shù)據(jù)并渲染
  actions, // 數(shù)據(jù)的異步操作
  mutations // 處理數(shù)據(jù)的唯一途徑,state的改變或賦值只能在這里
})
 
export default store // 導(dǎo)出store并在 main.js中引用注冊(cè)。

另種封裝

import Vue from 'vue'
import Vuex from 'vuex'
import user from './modules/user'
import getters from './getters'
Vue.use(Vuex)
/* eslint-disable no-new */
const store = new Vuex.Store({
 modules: {
  user //包含state、actions、mutations 
 },
 getters
})
export default store

2、getter

getter有點(diǎn)類似vue.js的計(jì)算屬性,當(dāng)我們需要從store的state中派生出一些狀態(tài),那么我們就需要使用getter,getter會(huì)接收state作為第一個(gè)參數(shù),而且getter的返回值會(huì)根據(jù)它的依賴被緩存起來(lái),只有g(shù)etter中的依賴值(state中的某個(gè)需要派生狀態(tài)的值)發(fā)生改變的時(shí)候才會(huì)被重新計(jì)算。

// 獲取最終的狀態(tài)信息

export const resturantName = state => state.resturantName

3、mutation

更改store中state狀態(tài)的唯一方法就是提交mutation,就很類似事件。每個(gè)mutation都有一個(gè)字符串類型的事件類型和一個(gè)回調(diào)函數(shù),我們需要改變state的值就要在回調(diào)函數(shù)中改變。我們要執(zhí)行這個(gè)回調(diào)函數(shù),那么我們需要執(zhí)行一個(gè)相應(yīng)的調(diào)用方法:store.commit。

// 提交 mutations是更改Vuex狀態(tài)的唯一合法方法
export const modifyAName = (state, name) => { // A組件點(diǎn)擊更改餐館名稱為 A餐館
  state.resturantName = name // 把方法傳遞過(guò)來(lái)的參數(shù),賦值給state中的resturantName
}
export const modifyBName = (state, name) => { // B組件點(diǎn)擊更改餐館名稱為 B餐館
  state.resturantName = name
}

4、action

action可以提交mutation,在action中可以執(zhí)行store.commit,而且action中可以有任何的異步操作。在頁(yè)面中如果我們要嗲用這個(gè)action,則需要執(zhí)行store.dispatch

// 給action注冊(cè)事件處理函數(shù)。當(dāng)這個(gè)函數(shù)被觸發(fā)時(shí)候,將狀態(tài)提交到mutations中處理
export function modifyAName({commit}, name) { // commit 提交;name即為點(diǎn)擊后傳遞過(guò)來(lái)的參數(shù),此時(shí)是 'A餐館'
  return commit ('modifyAName', name)
}
export function modifyBName({commit}, name) {
  return commit ('modifyBName', name)
}
 
// ES6精簡(jiǎn)寫(xiě)法
// export const modifyAName = ({commit},name) => commit('modifyAName', name)

5、module

module其實(shí)只是解決了當(dāng)state中很復(fù)雜臃腫的時(shí)候,module可以將store分割成模塊,每個(gè)模塊中擁有自己的state、mutation、action和getter。

6.在main.js中導(dǎo)入 store實(shí)例

import Vue from 'vue'
import App from './App'
import router from './router'
import store from './store'
 
Vue.config.productionTip = false
 
/* eslint-disable no-new */
new Vue({
 el: '#app',
 router,
 store, // 這樣就能全局使用vuex了
 components: { App },
 template: '<App/>'
})

7.對(duì)于1、3、4可以整合一個(gè)store/modules/user 的js進(jìn)行配合封裝

const user = {
 state: {
  resturantName: '飛歌餐館' // 默認(rèn)值
  // id: xxx 如果還有全局狀態(tài)也可以在這里添加
  // name:xxx
 },
 
 mutations: {
  // 提交 mutations是更改Vuex狀態(tài)的唯一合法方法
  modifyAName : (state, name) => { // A組件點(diǎn)擊更改餐館名稱為 A餐館
   state.resturantName = name // 把方法傳遞過(guò)來(lái)的參數(shù),賦值給state中的resturantName
  },
  modifyBName : (state, name) => { // B組件點(diǎn)擊更改餐館名稱為 B餐館
   state.resturantName = name
  }
 },
 actions: {
  // 給action注冊(cè)事件處理函數(shù)。當(dāng)這個(gè)函數(shù)被觸發(fā)時(shí)候,將狀態(tài)提交到mutations中處理
  modifyAName({commit}, name) { // commit 提交;name即為點(diǎn)擊后傳遞過(guò)來(lái)的參數(shù),此時(shí)是 'A餐館
   return commit ('modifyAName', name)
  },
  modifyBName({commit}, name) {
   return commit ('modifyBName', name)
  }
 
  // ES6精簡(jiǎn)寫(xiě)法
  //modifyAName:({commit},name) => commit('modifyAName', name)
 
 }
}
export default user

8.在組件A中,定義點(diǎn)擊事件,點(diǎn)擊 修改 名稱,并把 名稱在事件中用參數(shù)進(jìn)行傳遞。

...mapactions 和 ...mapgetters都是vuex提供的語(yǔ)法糖,在底層已經(jīng)封裝好了,拿來(lái)就能用,簡(jiǎn)化了很多操作。

其中...mapActions(['clickAFn']) 相當(dāng)于this.$store.dispatch('clickAFn',{參數(shù)}),mapActions中只需要指定方法名即可,參數(shù)省略。

...mapGetters(['resturantName'])相當(dāng)于this.$store.getters.resturantName

A組件同理

<template>
 <div class="componentsA">
   <P class="title">組件A</P>
   <P class="titleName">餐館名稱:{{resturantName}}</P>
   <div>
      <!-- 點(diǎn)擊修改 為 A 餐館 -->
     <button class="btn" @click="modifyAName('A餐館')">修改為A餐館</button>
   </div>
   <div class="marTop">
     <button class="btn" @click="trunToB">跳轉(zhuǎn)到B頁(yè)面</button>
   </div>
 </div>
</template>
 
<script>
import {mapActions, mapGetters} from 'vuex'
export default {
 name: 'A',
 data () {
  return {
  }
 },
 methods:{
   ...mapActions( // 語(yǔ)法糖
     ['modifyAName'] // 相當(dāng)于this.$store.dispatch('modifyName'),提交這個(gè)方法
   ),
   trunToB () {
     this.$router.push({path: '/componentsB'}) // 路由跳轉(zhuǎn)到B
   }
 },
 computed: {
   ...mapGetters(['resturantName']) // 動(dòng)態(tài)計(jì)算屬性,相當(dāng)于this.$store.getters.resturantName
 }
}
</script>

B組件同理

<template>
 <div class="componentsB">
   <P class="title">組件B</P>
   <P class="titleName">餐館名稱:{{resturantName}}</P>
   <div>
     <!-- 點(diǎn)擊修改 為 B 餐館 -->
     <button class="btn" @click="modifyBName('B餐館')">修改為B餐館</button>
   </div>
   <div class="marTop">
     <button class="btn" @click="trunToA">跳轉(zhuǎn)到A頁(yè)面</button>
   </div>
 </div>
</template>
 
<script>
import {mapActions, mapGetters} from 'vuex'
export default {
 name: 'B',
 data () {
  return {
  }
 },
 methods:{
   ...mapActions( // 語(yǔ)法糖
     ['modifyBName'] // 相當(dāng)于this.$store.dispatch('modifyName'),提交這個(gè)方法
   ),
   trunToA () {
     this.$router.push({path: '/componentsA'}) // 路由跳轉(zhuǎn)到A
   }
 },
 computed: {
   ...mapGetters(['resturantName']) // 動(dòng)態(tài)計(jì)算屬性,相當(dāng)于this.$store.getters.resturantName
 }
}
</script>

多組件的中狀態(tài)改變之dispatch 和 commit 的用法和區(qū)別

vue store存儲(chǔ)commit 和dispatch

dispatch:含有異步操作,例如向后臺(tái)提交數(shù)據(jù),寫(xiě)法: this.$store.dispatch('action方法名',值)

commit:同步操作,寫(xiě)法:this.$store.commit('mutations方法名',值)

以上這篇對(duì)vuex中store和$store的區(qū)別說(shuō)明就是小編分享給大家的全部?jī)?nèi)容了,希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。

相關(guān)文章

  • Storybook?7.0?Beta?Vue3踩坑解決記錄

    Storybook?7.0?Beta?Vue3踩坑解決記錄

    這篇文章主要為大家介紹了Storybook?7.0?Beta?Vue3踩坑解決記錄詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2023-02-02
  • 如何在Vue項(xiàng)目中應(yīng)用TypeScript類

    如何在Vue項(xiàng)目中應(yīng)用TypeScript類

    與如何在React項(xiàng)目中應(yīng)用TypeScript類類似在VUE項(xiàng)目中應(yīng)用typescript,我們需要引入一個(gè)庫(kù)vue-property-decorator,需要的小伙伴可續(xù)看下文具體介紹
    2021-09-09
  • Vue.js 父子組件通訊開(kāi)發(fā)實(shí)例

    Vue.js 父子組件通訊開(kāi)發(fā)實(shí)例

    這篇文章主要介紹了Vue.js 父子組件通訊開(kāi)發(fā)實(shí)例的相關(guān)資料,本文介紹的非常詳細(xì),具有參考借鑒價(jià)值,需要的朋友可以參考下
    2016-09-09
  • Vue?插件及瀏覽器本地存儲(chǔ)

    Vue?插件及瀏覽器本地存儲(chǔ)

    這篇文章主要介紹了Vue?插件及瀏覽器本地存儲(chǔ),插件通常用來(lái)為Vue添加全局功能,包含install方法的一個(gè)對(duì)象。更多相關(guān)介紹,需要的小伙伴可以參考下面文章內(nèi)容
    2022-05-05
  • vue安裝node-sass和sass-loader報(bào)錯(cuò)問(wèn)題的解決辦法

    vue安裝node-sass和sass-loader報(bào)錯(cuò)問(wèn)題的解決辦法

    這篇文章主要給大家介紹了關(guān)于vue安裝node-sass和sass-loader報(bào)錯(cuò)問(wèn)題的解決辦法,文中通過(guò)圖文以及示例代碼將解決的方法介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2023-01-01
  • 一文搞懂Vue2中的組件通信

    一文搞懂Vue2中的組件通信

    這篇文章主要為大家介紹了Vue2中的組件通信方式,文中通過(guò)示例進(jìn)行了詳細(xì)的介紹,對(duì)我們學(xué)習(xí)Vue有一定的幫助,感興趣的小伙伴可以了解一下
    2022-07-07
  • vite+ts vite.config.ts使用path報(bào)錯(cuò)問(wèn)題及解決

    vite+ts vite.config.ts使用path報(bào)錯(cuò)問(wèn)題及解決

    這篇文章主要介紹了vite+ts vite.config.ts使用path報(bào)錯(cuò)問(wèn)題及解決方案,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2023-10-10
  • Vue 無(wú)限滾動(dòng)加載指令實(shí)現(xiàn)方法

    Vue 無(wú)限滾動(dòng)加載指令實(shí)現(xiàn)方法

    這篇文章主要介紹了Vue 無(wú)限滾動(dòng)加載指令的實(shí)現(xiàn)代碼,本文通過(guò)實(shí)例代碼給大家介紹的非常詳細(xì),具有一定的參考借鑒價(jià)值 ,需要的朋友可以參考下
    2019-05-05
  • Vue常用的修飾符及應(yīng)用場(chǎng)景解讀

    Vue常用的修飾符及應(yīng)用場(chǎng)景解讀

    這篇文章主要介紹了Vue常用的修飾符及應(yīng)用場(chǎng)景解讀,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2022-10-10
  • vue兄弟組件傳遞數(shù)據(jù)的實(shí)例

    vue兄弟組件傳遞數(shù)據(jù)的實(shí)例

    今天小編就為大家分享一篇vue兄弟組件傳遞數(shù)據(jù)的實(shí)例,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧
    2018-09-09

最新評(píng)論