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

Vue Router初始化路由信息詳解

 更新時間:2023年11月22日 10:30:13   作者:BNTang  
這篇文章主要為大家詳細介紹了Vue Router初始化路由信息的相關(guān)知識,文中的示例代碼講解詳細,具有一定的借鑒價值,感興趣的小伙伴可以了解一下

前言

經(jīng)過上一節(jié)課的學(xué)習(xí),我們已經(jīng)完成了提取我們想要的路由信息數(shù)據(jù)格式,提取完畢了之后,接下來我們該干什么,接下來需要做的步驟就是監(jiān)聽路由的變化,保存當(dāng)前的路由。

那么就會遇到幾個問題,就是怎么監(jiān)聽,怎么保存,我們先回到 VueRouter 的官方文檔,點擊右上角的 API 參考,然后拖動到底部,在底部找到組件注入,當(dāng)中的注入的屬性:

其實我們在使用 VueRouter 的時候,只要你注冊了 VueRouter 之后,他會在每一個 Vue 實例中都添加兩個屬性,一個是 ,一個是,一個是router,一個是route,這兩個屬性是什么呢?

$router

其實對應(yīng)著就是我們自定義的 NueRouter 對象。

$route

$route 其實對應(yīng)著就是一個普通的對象,這個對象就保存了當(dāng)前的路由地址,等等等等一系列信息,所以為了將來能夠注入這兩個對象,我這里單獨寫一個類來存儲這兩個對象相關(guān)的信息。

代碼實現(xiàn)

class NueRouterInfo {
    constructor() {
        this.currentPath = null;
    }
}

通過這個類,我們就可以保存當(dāng)前的路由地址,默認等于 null,將來路由地址發(fā)生變化的時候,我們就可以修改這個值。

定義好了這個類我們是需要使用這個類,所以我們在哪里進行使用呢,我們在 NueRouter 類中進行使用,我們在 NueRouter 類中定義一個屬性,這個屬性就是 NueRouterInfo 的實例,然后在 NueRouter 的構(gòu)造函數(shù)中進行初始化路由信息。

首先定義 NueRouterInfo 的實例:

this.routerInfo = new NueRouterInfo();

然后在 NueRouter 的構(gòu)造函數(shù)中進行初始化路由信息,我這里定義一個 initDefault 方法,然后在這個方法中進行初始化路由信息,這個方法是在 NueRouter 的構(gòu)造函數(shù)中進行調(diào)用的。

在 initDefault 方法中,首先根據(jù)當(dāng)前的 mode 也就是路由模式來進行走不同分支的邏輯代碼,如果是 hash 模式,那么我們就需要監(jiān)聽 hashchange 事件,如果是 history 模式,那么我們就需要監(jiān)聽 popstate 事件。

這是其中的一步,我們的第一步其實并不是監(jiān)聽,首先要處理的就是,打開的界面先判斷 mode 模式如果是 hash,看看界面有沒有 hash,如果沒有就跳轉(zhuǎn)到 #/,如果有就不用管了,如果是 history 模式,那么就看看界面有沒有 history,如果沒有就跳轉(zhuǎn)到 /,如果有就不用管了。

第二步才是監(jiān)聽,監(jiān)聽的時候,我們需要將當(dāng)前的路由地址保存到 NueRouterInfo 的實例中,好了,我們來看看代碼怎么寫。

initDefault() {
    if (this.mode === 'hash') {
        // 1.判斷打開的界面有沒有hash, 如果沒有就跳轉(zhuǎn)到#/
        if (!location.hash) {
            location.hash = '/';
        }
        // 2.加載完成之后和hash發(fā)生變化之后都需要保存當(dāng)前的地址
        window.addEventListener('load', () => {
            this.routerInfo.currentPath = location.hash.slice(1);
        });
        window.addEventListener('hashchange', () => {
            this.routerInfo.currentPath = location.hash.slice(1);
            console.log(this.routerInfo);
        });
    } else {
        // 1.判斷打開的界面有沒有路徑, 如果沒有就跳轉(zhuǎn)到/
        if (!location.pathname) {
            location.pathname = '/';
        }
        // 2.加載完成之后和history發(fā)生變化之后都需要保存當(dāng)前的地址
        window.addEventListener('load', () => {
            this.routerInfo.currentPath = location.pathname;
        });
        window.addEventListener('popstate', () => {
            this.routerInfo.currentPath = location.pathname;
            console.log(this.routerInfo);
        });
    }
}

測試

代碼寫完了,我們來測試一下,先在 app.vue 中定義兩個 a 標簽 href 是 hash 模式代碼如下:

<template>
  <div id="app">
    <a href="#/home" rel="external nofollow" >首頁</a>
    <a href="#/about" rel="external nofollow" >關(guān)于</a>
  </div>
</template>
<style>
</style>

然后在更改一下 NueRouter 的傳參,將 mode 改成 hash 模式, 我們來測試第一步我們處理的邏輯,打開界面,看看有沒有 hash,如果沒有就跳轉(zhuǎn)到 #/,如果有就不用管了。

首先訪問:http://localhost:8080/ ,然后我們看看界面的地址欄,發(fā)現(xiàn)沒有 hash,默認就會跳轉(zhuǎn)到 #/:

然后我們再訪問:http://localhost:8080/#/home ,然后我們看看界面的地址欄,發(fā)現(xiàn)有 hash,就不用管了:

接下來我們測試第二步,監(jiān)聽 hashchange 事件,我們在 hashchange 事件中打印了 NueRouterInfo 的實例,看看有沒有保存當(dāng)前的路由地址,我們分別點擊首頁和關(guān)于,打印結(jié)果如下:

好了,hash 模式的測試就完成了,關(guān)于 history 模式需要編寫的代碼比較多,我這里就不帶著大家一起來驗證了,因為他們兩個都是同一個世界同一個夢想的。

到此為止,我們就完成了初始化路由信息的代碼編寫,接下來我們下一篇的內(nèi)容就是根據(jù)當(dāng)前的路由地址,找到對應(yīng)的組件,然后渲染到頁面上。

到此這篇關(guān)于Vue Router初始化路由信息詳解的文章就介紹到這了,更多相關(guān)Vue Router內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • Vue常見報錯整理大全(從此報錯不害怕)

    Vue常見報錯整理大全(從此報錯不害怕)

    寫代碼的過程中一定會遇到報錯,遇到報錯不要擔(dān)心,認真分析就可以解決報錯,同時積累經(jīng)驗,早日成為大牛,這篇文章主要給大家介紹了關(guān)于Vue常見報錯整理的相關(guān)資料,需要的朋友可以參考下
    2022-08-08
  • vue中使用echarts刷新可以正常渲染但路由跳轉(zhuǎn)不顯示的問題解決

    vue中使用echarts刷新可以正常渲染但路由跳轉(zhuǎn)不顯示的問題解決

    在?Vue?中使用?ECharts?組件時,遇到路由跳轉(zhuǎn)后圖表不顯示的問題可能是因為組件銷毀和重新創(chuàng)建的原因,所以本文給大家介紹了vue中使用echarts刷新可以正常渲染但路由跳轉(zhuǎn)不顯示問題的解決方法,需要的朋友可以參考下
    2024-02-02
  • Vue彈窗的兩種實現(xiàn)方式實例詳解

    Vue彈窗的兩種實現(xiàn)方式實例詳解

    這篇文章主要介紹了Vue彈窗的兩種實現(xiàn)方式,一種使用.sync修飾符另一種使用v-model,本文通過實例代碼給大家介紹的非常詳細,需要的朋友可以參考下
    2022-08-08
  • 在Vue中實現(xiàn)文件預(yù)覽與打印的代碼示例

    在Vue中實現(xiàn)文件預(yù)覽與打印的代碼示例

    在Vue應(yīng)用中,有時我們需要實現(xiàn)文件預(yù)覽和打印的功能,比如,我們可能需要預(yù)覽并打印PDF文件、圖片文件等,本文將介紹如何在Vue中實現(xiàn)文件預(yù)覽和打印的功能,并提供相應(yīng)的代碼示例
    2023-06-06
  • TSX常見簡單入門用法之Vue3+Vite

    TSX常見簡單入門用法之Vue3+Vite

    Vue3的確可以直接使用tsx開發(fā),唯一需要處理的就是children,而且處理起來還是比較不爽的,下面這篇文章主要給大家介紹了關(guān)于TSX常見簡單入門用法之Vue3+Vite的相關(guān)資料,需要的朋友可以參考下
    2022-08-08
  • vue組件暴露和.js文件暴露接口操作

    vue組件暴露和.js文件暴露接口操作

    這篇文章主要介紹了vue組件暴露和.js文件暴露接口操作,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2020-08-08
  • 如何監(jiān)聽Vue項目報錯的4種方式?

    如何監(jiān)聽Vue項目報錯的4種方式?

    本文主要介紹了如何監(jiān)聽Vue項目報錯的4種方式,文中通過示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2022-04-04
  • Vue終端取消vue、prettier警告warn問題

    Vue終端取消vue、prettier警告warn問題

    這篇文章主要介紹了Vue終端取消vue、prettier警告warn問題,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2023-10-10
  • vue實現(xiàn)輸入框只允許輸入數(shù)字

    vue實現(xiàn)輸入框只允許輸入數(shù)字

    在vue項目中,輸入框只允許輸入數(shù)字,現(xiàn)將自己使用的一種方法記錄,本文結(jié)合實例代碼給大家介紹的非常詳細,感興趣的朋友一起看看吧
    2023-11-11
  • 關(guān)于Vue不能監(jiān)聽(watch)數(shù)組變化的解決方法

    關(guān)于Vue不能監(jiān)聽(watch)數(shù)組變化的解決方法

    本文主要介紹了Vue不能監(jiān)聽(watch)數(shù)組變化的解決方法,文中通過示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2021-09-09

最新評論