亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

Vuex的安裝、搭建及案例詳解

 更新時(shí)間:2022年05月23日 11:20:42   作者:游坦之  
vuex是一個(gè)專門為vue開發(fā)的狀態(tài)管理工具,它采用集中式存儲(chǔ)管理應(yīng)用的所有組件的狀態(tài),其核心是state,下面這篇文章主要給大家介紹了關(guān)于Vuex的安裝、搭建及案例的相關(guān)資料,需要的朋友可以參考下

前言

本文講訴了Vuex的安裝、搭建。以及Actions、Mutations、State、Getters的使用,為什么使用mapState、mapGetters以及一些細(xì)節(jié)的解釋

Vuex原理講解 

Actions:詞義是 動(dòng)作行為

Mutations:詞義是加工、維護(hù)

State:詞義是 狀態(tài)和數(shù)據(jù)

Dispatch:詞義是派遣、發(fā)出

Commit:提交

Render: 渲染

Mutate:轉(zhuǎn)變

從這些單詞中,大體上可以概括整個(gè)圖的流程。

VC派發(fā)(Dispatch)消息到Actions,Actions提交(Commit)到Mutation,Mutation轉(zhuǎn)變(Mutate)state,然后重新渲染整個(gè)頁面。

1、安裝vuex組件

注意:vue3只能用vuex4版本,vue2只能用vuex3版本。2022年2月7日之后,vue3成了默認(rèn)版本,vuex4相應(yīng)的也成了默認(rèn)版本。所以對于vue2,要注明vuex的版本 @3

在package.json里看到vuex就說明安裝成功了

2、使用Vuex

首先需要?jiǎng)?chuàng)建一個(gè)Store。

在Src中,創(chuàng)建一個(gè)名為store的文件夾,里面包含一個(gè)index.js的文件

 由上面那個(gè)原理圖可以看出來,store里面至少包含Actions,Mutations,State。

如下圖

(創(chuàng)建Store實(shí)例,需要用到Vuex.Store所以需要引用Vuex)

Vue.use(Vuex)的作用就是讓vue承認(rèn)store這個(gè)屬性,否則初始化Vc的時(shí)候,vue不會(huì)解析store這個(gè)屬性

main.js配置如下

 其中store相當(dāng)于store:store。根據(jù)ES6語法規(guī)則,如果key和value一樣,可以簡寫成key的形式

import Vue from 'vue'
import App from './App.vue'
Vue.config.productionTip = false
import store from './store'
new Vue({
  render: h => h(App),
  store
}).$mount('#app')

這樣Vuex的架子就搭好了,實(shí)戰(zhàn)演練一下,并借此機(jī)會(huì)深入的介紹一下Vuex里面的屬性。

求和案例

流程講解:點(diǎn)擊button按鈕,觸發(fā)點(diǎn)擊事件,派發(fā)消息去Actions里面找addSum,并且攜帶參數(shù)1。在Actions里面,接受參數(shù),向Mutation提交,攜帶參數(shù)1。Mutation里改變state里的sum的值,vue檢測到sum改變,重新渲染整個(gè)頁面。

效果圖:

Coute.vue

<template>
    <div>
        <h1>當(dāng)前的值是:{{sum}}</h1>
        <button @click="addSum">點(diǎn)我加1</button>
        <button>點(diǎn)我減1</button>
    </div>
</template>
 
<script>
export default {
    name:"Coute",
    methods:{
        addSum()
        {
            this.$store.dispatch('addSum',1);
        }
    },
    computed:{
        sum()
        {
            return this.$store.state.sum;
        }
    }
}
</script>
 
<style>
    button{
        margin-right: 2px;
    }
</style>

store.js

import Vuex from 'vuex'
import Vue from 'vue'
Vue.use(Vuex)
const state = {
    sum:1
};
const mutations={
    ADDSUM(state,value)
    {
        state.sum+=value;
    }
};
const actions={
    addSum(context,value)
    {
        context.commit('ADDSUM',value);
    }
};
export default new Vuex.Store({
    state,
    mutations,
    actions
})

詳細(xì)看一下Action和Mutations里面的可以攜帶參數(shù)

Actions

設(shè)置四個(gè)參數(shù),并打印一下。

結(jié)果只輸出了兩個(gè)參數(shù),第一個(gè)參數(shù)是一個(gè)對象,里面包含了commit,dispatch等屬性,第二個(gè)參數(shù)就是要攜帶的值;

其中第二個(gè)參數(shù)叫做value,第一個(gè)參數(shù)通常叫做Context,里面最常用的是Commit。如果只想獲得Commit也可以寫成這種形式

 Mutations

同樣Mutations里面也是只有兩個(gè)參數(shù),其中第一個(gè)是state(看到了sum),第二個(gè)就是攜帶的、值。Mutations最大的作用就是可以改變state的值。 

疑問:為什么需要一個(gè)Actions,求和案例之中,我把參數(shù)傳給Actions,Actions原封不動(dòng)的又傳給了Mutations,為什么我不直接傳給Mutations呢?

答:確實(shí)是這樣子。如果參數(shù)確定的話,可以跳過Actions,直接commit到Mutations里面。但是如果參數(shù)不確定的話,比如我需要向服務(wù)器要數(shù)據(jù),這時(shí)候就必須用到Actions發(fā)送Ajax。

getters的使用:

如果多個(gè)組件都用到一個(gè)對state里數(shù)據(jù)處理過的值,比如求和案例中sum的20倍。通過getters僅處理一次,就可以讓多個(gè)組件同時(shí)使用。

store

import Vuex from 'vuex'
import Vue from 'vue'
Vue.use(Vuex)
const state = {
    sum:1
};
const mutations={
    ADDSUM(state,value)
    {
         state.sum+=value
    }
};
const actions={
    addSum({commit},value)
    {
         commit('ADDSUM',value)
    }
};
const getters = {
    bigSum(state)
    {
        return state.sum*20
    }
}
export default new Vuex.Store({
    state,
    mutations,
    actions,
    getters
})

Store倉庫數(shù)據(jù)的使用:

現(xiàn)在我們有多個(gè)數(shù)據(jù),怎么樣在任意組件里面訪問的到呢?為了表現(xiàn)出組件之間的通信。新建一個(gè)組件Information

答案就是在Computed里面獲得

<template>
  <div>
      <h1>姓名:{{name}}</h1>
      <h1>學(xué)校:{{school}}</h1>
      <h1>爵位:{{Marquis}}</h1>
  </div>
</template>
 
<script>
export default {
    name:'Information',
    computed:{
        school()
        {
            return this.$store.state.school;
        },
        sum()
        {
            return this.$store.state.sum;
        },
        name()
        {
            return this.$store.state.name;
        },
        Marquis()
        {
            return this.$store.state.Marquis;
        }
    }
}
</script>
 
<style>
 
</style>

效果圖

GetState 的引入

由上圖所示,這樣一個(gè)一個(gè)的寫,雖然可以寫出來,但是實(shí)在是太麻煩了。干的都是一樣的工作。所以Vue給我們提供了一個(gè)方法。mapState和mapGetters。這兩個(gè)一個(gè)是簡化State里的屬性,一個(gè)是簡化getters里面的屬性。

第一種方法可以簡寫成下面這種形式。(對象寫法。函數(shù)的名字可以隨意)

 為什么要用...mapState。 原因:mapState報(bào)錯(cuò)

 為什么報(bào)錯(cuò)呢?

輸出一下mapState()來看看。

 mapState里面是一個(gè)對象。computed本身也是一個(gè)對象。{}里面再加一個(gè){},是肯定會(huì)報(bào)錯(cuò)的。 那為什么用...呢,ES6用法中,一個(gè)對象t1,一個(gè)對象t2,t1{...t2}就相當(dāng)于,把t2中的屬性全拿出來一個(gè)個(gè)放到t1里面。

第二種方法:數(shù)組方法(state里面的屬性是什么就必須寫什么)

 效果都是可以的

mapGetters同理,就不贅述了 

【錯(cuò)誤示范--使用Vuex時(shí)】

Vue.use(Vuex)在main.js里面使用

main.js

import Vue from 'vue'
import App from './App.vue'
import Vuex from 'vuex'
Vue.use(Vuex)
Vue.config.productionTip = false
import store from './store'
new Vue({
  render: h => h(App),
  store
}).$mount('#app')
import Vuex from 'vuex'
 
const state = {
   
};
const mutations={
    
};
const actions={
    
};
const getters = {
    
}
export default new Vuex.Store({
    state,
    mutations,
    actions,
    getters
})

你發(fā)現(xiàn)報(bào)了一個(gè)這樣的錯(cuò)誤(Vue.use(Vuex)應(yīng)該在創(chuàng)建store之前執(zhí)行),然后仔細(xì)檢查了一遍,確認(rèn)Vue.use(Vuex)寫在了引入store之前。為什么還報(bào)錯(cuò)呢?這里我想說的就是Vue在解析代碼的時(shí)候,會(huì)按順序首先執(zhí)行所有的import的語句,所以Vue.use(Vuex)只能寫在store里面

【報(bào)錯(cuò)】

 語法校驗(yàn)不過關(guān),在vue.config.js加上這句lintOnSave:false(關(guān)閉語法校驗(yàn))

總結(jié)

到此這篇關(guān)于Vuex安裝搭建及案例詳解的文章就介紹到這了,更多相關(guān)Vuex詳解內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • Vue實(shí)現(xiàn)點(diǎn)擊當(dāng)前元素以外的地方隱藏當(dāng)前元素(實(shí)現(xiàn)思路)

    Vue實(shí)現(xiàn)點(diǎn)擊當(dāng)前元素以外的地方隱藏當(dāng)前元素(實(shí)現(xiàn)思路)

    這篇文章主要介紹了Vue實(shí)現(xiàn)點(diǎn)擊當(dāng)前元素以外的地方隱藏當(dāng)前元素,文中給大家擴(kuò)展了vue實(shí)現(xiàn)點(diǎn)擊其他地方隱藏div的三種方法,需要的朋友可以參考下
    2019-12-12
  • 對Vue2 自定義全局指令Vue.directive和指令的生命周期介紹

    對Vue2 自定義全局指令Vue.directive和指令的生命周期介紹

    今天小編就為大家分享一篇對Vue2 自定義全局指令Vue.directive和指令的生命周期介紹,具有很好的參考價(jià)值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2018-08-08
  • 如何在Vue中使用debouce防抖函數(shù)

    如何在Vue中使用debouce防抖函數(shù)

    本文主要介紹在Vue中使用debouce防抖函數(shù),設(shè)置一個(gè)門檻值,表示兩次?Ajax?通信的最小間隔時(shí)間。如果在間隔時(shí)間內(nèi),發(fā)生新的keydown事件,則不觸發(fā)?Ajax?通信,并且重新開始計(jì)時(shí)。如果過了指定時(shí)間,沒有發(fā)生新的keydown事件再將數(shù)據(jù)發(fā)送出去,這便是debouce防抖函數(shù)
    2021-12-12
  • Proxy中代理數(shù)據(jù)攔截的方法詳解

    Proxy中代理數(shù)據(jù)攔截的方法詳解

    這篇文章主要為大家詳細(xì)介紹了Proxy中代理數(shù)據(jù)攔截的方法,文中的示例代碼講解詳細(xì),對我們學(xué)習(xí)或工作具有一定的借鑒價(jià)值,需要的可以參考一下
    2022-12-12
  • vue項(xiàng)目中axios請求網(wǎng)絡(luò)接口封裝的示例代碼

    vue項(xiàng)目中axios請求網(wǎng)絡(luò)接口封裝的示例代碼

    這篇文章主要介紹了vue項(xiàng)目中axios請求網(wǎng)絡(luò)接口封裝的示例代碼,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧
    2018-12-12
  • Vue實(shí)現(xiàn)動(dòng)態(tài)顯示表單項(xiàng)填寫進(jìn)度功能

    Vue實(shí)現(xiàn)動(dòng)態(tài)顯示表單項(xiàng)填寫進(jìn)度功能

    這篇文章主要介紹了Vue實(shí)現(xiàn)動(dòng)態(tài)顯示表單項(xiàng)填寫進(jìn)度功能,此功能可以幫助用戶了解表單填寫的進(jìn)度和當(dāng)前狀態(tài),提高用戶體驗(yàn),通常實(shí)現(xiàn)的方式是在表單中添加進(jìn)度條,根據(jù)用戶填寫狀態(tài)動(dòng)態(tài)更新進(jìn)度條,感興趣的同學(xué)可以參考下文
    2023-05-05
  • vscode中的vue項(xiàng)目報(bào)錯(cuò)Property ‘xxx‘ does not exist on type ‘CombinedVueInstance<{ readyOnly...Vetur(2339)

    vscode中的vue項(xiàng)目報(bào)錯(cuò)Property ‘xxx‘ does not exist on type ‘Combin

    這篇文章主要介紹了vscode中的vue項(xiàng)目報(bào)錯(cuò)Property ‘xxx‘ does not exist on type ‘CombinedVueInstance<{ readyOnly...Vetur(2339),文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2020-09-09
  • 在vue中使用vuex,修改state的值示例

    在vue中使用vuex,修改state的值示例

    今天小編就為大家分享一篇在vue中使用vuex,修改state的值示例,具有很好的參考價(jià)值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2019-11-11
  • vue視頻播放插件vue-video-player的具體使用方法

    vue視頻播放插件vue-video-player的具體使用方法

    這篇文章主要介紹了vue視頻播放插件vue-video-player的具體使用方法,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2019-11-11
  • VSCode創(chuàng)建Vue項(xiàng)目的完整步驟教程

    VSCode創(chuàng)建Vue項(xiàng)目的完整步驟教程

    Vue是一個(gè)輕量級、漸進(jìn)式的Javascript框架,如果想要要開發(fā)全新的Vue項(xiàng)目,建議項(xiàng)目構(gòu)建工具vue-cli,下面這篇文章主要給大家介紹了關(guān)于VSCode創(chuàng)建Vue項(xiàng)目的完整步驟,需要的朋友可以參考下
    2022-06-06

最新評論