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

Vuex與Vue router的使用詳細(xì)講解

 更新時(shí)間:2022年11月03日 08:40:37   作者:GG_Bonin  
在看這篇文章的幾點(diǎn)要求:需要你先知道Vuex與Vue-Router是個(gè)什么東西,用來解決什么問題,以及它的基本使用。如果你還不懂的話,建議上官網(wǎng)了解下Vuex與Vue-Router的基本使用后再回來看這篇文章

Vuex的使用

在Vue中實(shí)現(xiàn)集中式狀態(tài)(數(shù)據(jù))管理的一個(gè)Vue插件,對(duì)vue應(yīng)用中多個(gè)組件的共享狀態(tài)進(jìn)行集中式的管理(讀/寫),也是一種組件間通信的方式,用于任意組件間的通信

state:存儲(chǔ)數(shù)據(jù)的地址

actions:中轉(zhuǎn)站,可發(fā)送異步請(qǐng)求增加判斷

mutations:真正改state數(shù)據(jù)的地方

Vuex的使用流程

- 第一步:在state中定義變量

- 第二步:在組件中通過 this.$store.dispatch('actions中定義的函數(shù)'),觸發(fā)actions中得函數(shù)執(zhí)行

- 第三步:在actions中的函數(shù)中,調(diào)用context.commit('mutations中定義的函數(shù)')

- 第四步:在mutations中定義的函數(shù)實(shí)現(xiàn)真正的修改state中的數(shù)據(jù)

- 第五步:頁面中只要使用$store.state.變量,變量變化,頁面就變化 實(shí)現(xiàn)了組件間的通信

?? 注意點(diǎn):

- 在組件中可以直接調(diào)用commit觸發(fā)(mutations中定義的函數(shù))

- 在組件中可以直接修改state中定義變量

Vuex的執(zhí)行流程圖

執(zhí)行流程:

- 用戶進(jìn)行操作,通過dipatch提交一個(gè)actions

-actions接收到這個(gè)事件之后,在actions中可以執(zhí)行一些異步或者同步操作,然后根據(jù)不同的情況去分發(fā)給不同的mutations

-actions通過commit去觸發(fā)mutations

-最后mutations去更新state數(shù)據(jù)值,state更新之后,就會(huì)通知vue渲染頁面并顯示

Vuex偽代碼

   export default new Vuex.Store({
    state:{
        // 存放真正的變量,也就是數(shù)據(jù)
    },
    mutations:{
        // 修改state的數(shù)據(jù)操作
    },
    actions:{
        // 可以進(jìn)行異步同步請(qǐng)求,校驗(yàn)權(quán)限等操作
    }
})

Vue-router的使用

官方提供的用來實(shí)現(xiàn)SPA 的vue插件,有了它以后我們可以寫很多頁面組件,通過地址欄路徑的不同來顯示不同的頁面組件

基本使用流程

- 安裝插件:

cnpm install vue-router@4

- 在src目錄下新建router文件夾內(nèi)再創(chuàng)index.js文件用來存放路由

- 在index.js中引入插件

import Vue from 'vue'//引入vue
import VueRouter from 'vue-router'//引入vue-router路由模塊
Vue.use( VueRouter ) //使用vue-router這個(gè)第三方插件

- 創(chuàng)建了一個(gè)router對(duì)象實(shí)例并導(dǎo)出

const routes = [
    {
        path: '/',
        name: 'home',
        component: Home
    },
]
export default router //導(dǎo)出

-入口文件main.js中引入路由實(shí)例 router

new Vue({
  router,
  render: h => h(App)
}).$mount('#app')

- 在App.vue中用一個(gè) router-view 的組件來給路由一個(gè)展示區(qū)域

<template>
  <div id="app">
    <router-view>
    </router-view>
  </div>
</template>

路由的跳轉(zhuǎn)

- 在html中使用

router-link組件:可以在不重新加載頁面的情況下更改URl處理URl的生成以及編碼

to:來指定跳轉(zhuǎn)的鏈接

<div id ="app">
    <p>
    <router-link to="/home">首頁</router-link>
    </p>
</div>

- 在js中使用

當(dāng)需要先進(jìn)行權(quán)限判斷的時(shí)候需要在js中進(jìn)行跳轉(zhuǎn),校驗(yàn)通過跳轉(zhuǎn)刪除校驗(yàn)不通過跳轉(zhuǎn)到登陸

export default {
    Todel() {
        if (usernane) {
            this.$router.push('/del')
        }else{
            this.$router.push('/login')
        }
    }
}

攜帶參數(shù)的路由跳轉(zhuǎn)

- 在請(qǐng)求地址中帶參數(shù)

<div id ="app">
    <p>
    <router-link to="/login/?username=abc&password=123">用戶登陸</router-link>
    </p>
</div>

在跳轉(zhuǎn)頁面的組件中接受:

this.$route.query.username
this.$route.query.password

- 在地址中帶參數(shù)

<div id ="app">
    <p>
    <router-link to="/bookList/1">展示書籍</router-link>
    </p>
</div>

在跳轉(zhuǎn)頁面的組件中接受:

this.$route.params.

路由嵌套

關(guān)鍵字:children

在router/index.js相應(yīng)的路由中通過關(guān)鍵字進(jìn)行路由的嵌套

const routes = [
    {
        path: '/login',
        name: 'login',
        component: Login,
        children: [
            {
                name: 'books',
                path: 'books',
                component: Books
            },
]

?? 注意點(diǎn):

- 必須要在Login組件中加<router-view></router-view>用來渲染子路由

- 只會(huì)變更login下router-view包裹的位置

路由守衛(wèi)

- 前置路由守衛(wèi):有時(shí)候根據(jù)用戶的權(quán)限區(qū)分普通用戶訪問的接口與超級(jí)用戶才能訪問的接口,設(shè)置守衛(wèi)來區(qū)分

router.beforeEach((to, from, next) => {
    console.log('前置路由守衛(wèi)', to, from)
    if (to.name == 'shoppingcart') {
        let name = localStorage.getItem('name')
        if (name) {
            next()
        } else {
            alert('不好意思沒有權(quán)限')
        }
    } else {
        next()
    }
})

- 后置路由守衛(wèi):用來設(shè)置跳轉(zhuǎn)后頁面標(biāo)題的名字,根據(jù)頁面組件名字設(shè)置頁面名

router.afterEach((to,from)=>{
	console.log('后置路由守衛(wèi)',to,from)
	document.title = to.name
})

到此這篇關(guān)于Vuex與Vue router的使用詳細(xì)講解的文章就介紹到這了,更多相關(guān)Vuex與Vue router內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • vue-router history模式下的微信分享小結(jié)

    vue-router history模式下的微信分享小結(jié)

    本篇文章主要介紹了vue-router history模式下的微信分享小結(jié),小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧
    2018-07-07
  • Vue組件與生命周期詳細(xì)講解

    Vue組件與生命周期詳細(xì)講解

    Vue的生命周期就是vue實(shí)例從創(chuàng)建到銷毀的全過程,也就是new Vue() 開始就是vue生命周期的開始。Vue 實(shí)例有?個(gè)完整的?命周期,也就是從開始創(chuàng)建、初始化數(shù)據(jù)、編譯模版、掛載Dom -> 渲染、更新 -> 渲染、卸載 等?系列過程,稱這是Vue的?命周期
    2022-10-10
  • highCharts提示框中顯示當(dāng)前時(shí)間的方法

    highCharts提示框中顯示當(dāng)前時(shí)間的方法

    今天小編就為大家分享一篇關(guān)于highCharts提示框中顯示當(dāng)前時(shí)間的方法,小編覺得內(nèi)容挺不錯(cuò)的,現(xiàn)在分享給大家,具有很好的參考價(jià)值,需要的朋友一起跟隨小編來看看吧
    2019-01-01
  • vue2使用element-ui,el-table不顯示,用npm安裝方式

    vue2使用element-ui,el-table不顯示,用npm安裝方式

    這篇文章主要介紹了vue2使用element-ui,el-table不顯示,用npm安裝方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2023-07-07
  • vue循環(huán)數(shù)組改變點(diǎn)擊文字的顏色

    vue循環(huán)數(shù)組改變點(diǎn)擊文字的顏色

    這篇文章主要為大家詳細(xì)介紹了vue循環(huán)數(shù)組改變點(diǎn)擊文字的顏色,非常實(shí)用的切換效果,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2019-10-10
  • vue-electron中修改表格內(nèi)容并修改樣式

    vue-electron中修改表格內(nèi)容并修改樣式

    本文主要介紹了vue-electron中修改表格內(nèi)容并修改樣式,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2023-05-05
  • vue項(xiàng)目中的public、static及指定不編譯文件問題

    vue項(xiàng)目中的public、static及指定不編譯文件問題

    這篇文章主要介紹了vue項(xiàng)目中的public、static及指定不編譯文件問題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2023-03-03
  • vite2.x實(shí)現(xiàn)按需加載ant-design-vue@next組件的方法

    vite2.x實(shí)現(xiàn)按需加載ant-design-vue@next組件的方法

    這篇文章主要介紹了vite2.x實(shí)現(xiàn)按需加載ant-design-vue@next組件的方法,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2021-03-03
  • Vue中Mixin的正確用法詳解

    Vue中Mixin的正確用法詳解

    眾所周知,vue 的 mixins 是個(gè)非常靈活,但又很容易帶來混亂的 API,Mixins 本該是一種強(qiáng)大的重用代碼的手段,但使用之后往往帶來更多的混亂,代碼變得不易維護(hù),本文就詳細(xì)介紹Vue Mixin的正確用法,需要的朋友可以參考下
    2023-06-06
  • 關(guān)于Vue v-on指令的使用

    關(guān)于Vue v-on指令的使用

    這篇文章主要介紹了關(guān)于Vue v-on指令的一些使用場(chǎng)景,比如監(jiān)聽事件、傳入event參數(shù)、事件修飾符的一些場(chǎng)景,下面就來看看具體使用的方法吧,需要的朋友可以參考一下
    2021-10-10

最新評(píng)論