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

詳解Vue中的路由與多種守衛(wèi)

 更新時間:2023年02月02日 10:29:29   作者:Aic山魚  
路由守衛(wèi)又稱導(dǎo)航守衛(wèi),指是路由跳轉(zhuǎn)前、中、后過程中的一些鉤子函數(shù),這篇文章主要介紹了Vue中的路由與多種守衛(wèi),需要的朋友可以參考下

什么是路由呢?

路由其實是一種映射關(guān)系。

生活中的路由:設(shè)備和ip的映射關(guān)系;

node.js路由:接口和服務(wù)的 映射關(guān)系;

(前端)Vue中的路由:路徑和組件的映射關(guān)系。

什么是路由守衛(wèi)呢?

如果在面試中被問到了這個,比較完美的答案如下:

路由守衛(wèi)又稱導(dǎo)航守衛(wèi),指是路由跳轉(zhuǎn)前、中、后過程中的一些鉤子函數(shù)。官方解釋是vue-router提供的導(dǎo)航守衛(wèi),要通過跳轉(zhuǎn)或取消的方式來守衛(wèi)導(dǎo)航。路由守衛(wèi)分為三種,全局路由、組件內(nèi)路由,路由獨享。

全局路由鉤子函數(shù)有:beforeEach、beforeResolve、afterEach(參數(shù)中沒有next)

組件內(nèi)路由的鉤子函數(shù)有:beforeRouterEnter、beforeRouteUpdate、beforeRouteLeave

路由獨享的鉤子函數(shù)有:beforeEnter

1.vue-router

vue的一個插件庫,專門用來實現(xiàn)對SPA應(yīng)用的單頁Web應(yīng)用(single page web application, SPA)。整個應(yīng)用只有一個完整的頁面。點擊頁面中的導(dǎo)航鏈接不會刷新頁面,只會做頁面的局部更新。數(shù)據(jù)需要通過ajax請求獲取。

2.什么是路由

  1. 一個路由就是一組映射關(guān)系(key :value)

key 為路徑, value可能是function或componente

路由分類

1.后端路由:value 杲function,用于處理客戶端提交的請求。工作過程: 服務(wù)器接收到一個請求時,根據(jù)請求路徑找到匹配的函數(shù)來處理請求,返回響應(yīng)數(shù)據(jù)。

2.前端路由: value是component,用于展示頁面內(nèi)容。工作過程: 當瀏覽器的路徑改變時,對應(yīng)的組件就會顯示。

3.路由的基本使用

1.安裝vue-router

npm i vue-router

2.應(yīng)用插件

Vue.use(VueRouter)

3.router配置項

//  引入vueRouter
importvueRouterfrom'vue-router'
// 引入組件
importAboutfrom'../components/About'
importHomefrom'../components/Home'
export default new vueRouter({
     routes: [{
             path: '/about',
             component: About
         },
         {
             path: '/home',
             component: Home
         },
     ]

})

4.使用router-link實現(xiàn)切換(注:router-link經(jīng)過瀏覽器后就會變成a標簽哦)

        <divclass="list-group">
          <!-- 原始寫法——使用a標簽進行頁面的跳轉(zhuǎn) -->
          <!-- <a class="list-group-item active" href="./about.html" rel="external nofollow" >About</a>
          <a class="list-group-item" href="./home.html" rel="external nofollow" >Home</a>-->
          <!-- 使用vue-Router提供的標簽進行路徑的修改,實現(xiàn)路由的切換 -->
          <router-link 
            class="list-group-item"
            active-class="active"
            to="/about">About
           </router-link>
          <router-link 
            class="list-group-item"
            active-class="active"
            to="/home">Home
           </router-link>
        </div>

5.使用router-view實現(xiàn)組件的呈現(xiàn)(類似于插槽)

          <divclass="panel-body">
            <!-- 指定組件的呈現(xiàn)位置 -->
            <router-view>
            </router-view>
          </div>
注:1.路由組件通常存放在pages文件夾,所以不要往components文件夾里面放了
2.通過切換,“隱藏” 了的路由組件,默認是被銷毀掉的,需要的時候再去掛載
3.每個組件都有自己的$route屬性,里面存儲著自己的路由信息。
4.整個應(yīng)用只有一個router, 可以通過組件的$router屬性獲取到。

4.多級路由

在配置路由規(guī)則的以及路由里面進行配置下一級路由使用children:[ { } ]這種形式

    routes: [{
            path: '/about',
            component: About
        },
        {
            path: '/home',
            component: Home,
            children: [{
                    path: 'news',
                    component: News
                },
                {
                    path: 'message',
                    component: Message
                }
            ]
        },
    ]

5.路由傳參

有兩種方式,第一種就是直接再路徑里面寫query參數(shù),第二種就是params傳參

路由命名(簡化代碼)

再to的時候就不用寫一大堆路徑了

1.params

1. 配置路由聲明接受params參數(shù)

 
                    children:[
                        {
                            name:'xiangqing',
                            path:'detail/:id/:title',// 使用占位符聲明接收參數(shù)
                            component:Detail,
                        }
                    ]

2.傳遞參數(shù)

<!-- 跳轉(zhuǎn)路由并攜帶params參數(shù),to的字符串寫法 -->
        <router-link:to="`/home/message/detail/${m.id}/${m.title}`">{{m.title}}</router-link>
        <!-- 跳轉(zhuǎn)路由并攜帶params參數(shù),to的對象寫法 -->
        <router-link
          :to="{
            // 簡化路徑代碼
            name:'xiangqing',// 必須使用name,不能使用path
             //  params:所攜帶的參數(shù)
            params:{
                id:m.id,
                title:m.title,
            }
        }"
        >{{m.title}}</router-link>

3,接受參數(shù)

    <div>
        <ul>
            <!-- params寫法 -->
            <li>消息:{{$route.params.id}}</li>
            <li>編號:{{$route.params.title}}</li>
        </ul>
    </div>

2.路由的props配置

一共有三種配置方法,分別是對象式,布爾值式,函數(shù)式目的是讓路由組件更方便的接受到參數(shù)

children: [{
    name: 'xiangqing',
    // path: 'detail/:id/:title', // 使用占位符聲明接收參數(shù)
    path: 'detail', // query不使用占位符聲明接收參數(shù)
    component: Detail,
    // props的第一種寫法
    // props:{a:"1",b:"2"},
    // 第二種寫法,值為布爾值,若布爾值為真,就會把該路由組件收到的所有params參數(shù),以props的形式傳給Detail
    // props:true,
    // props的第三種寫法,值為函數(shù)
    props($route) {// 使用解構(gòu)賦值連續(xù)寫法簡化代碼
        return {id:$route.query.id,title:$route.query.title}
    }
    // props({query:{id,title}}) {// 使用解構(gòu)賦值連續(xù)寫法簡化代碼
    //     return {id,title}
    // }
}]

3.<router -link>的replace屬性

1.作用:控制路由跳轉(zhuǎn)時操作瀏覽器歷史記錄的模式

2.瀏覽器的歷史記錄有兩種寫入方式:分別為push和replace,push 是追加歷史記錄,replace 是替換當前記錄。路由跳轉(zhuǎn)時候默認為push,所以為push的時候可以進行后退前進操作,而replace直接就是替換掉之前的那個地址所以在replace的里面智慧存在一個地址,也就是當前所呈現(xiàn)的那個地址,就好比做核算,push是排隊的人,replace是做核酸的醫(yī)務(wù)人員

3.如何開啟replace模式:<router-link replace ...... >News</router- link>即可

4.編程式路由導(dǎo)航

1.作用:不借助<router- link>實現(xiàn)路由跳轉(zhuǎn),讓路由跳轉(zhuǎn)更加靈活

  methods: {
      //后退
    back() {
      this.$router.back();
    },
      //前進
    forward() {
      this.$router.forward();
    },
      //可以后退也可以前進
    test() {
      this.$router.go(-2);
    }
  }

5.緩存路由組件

1.作用:讓不展示的路由組件保持掛載,不被銷毀。

2.具體實現(xiàn)方法

<keep-alivelinclude= "News">
K router-view></router-view>
</keep-alive>

兩個新的生命周期鉤子

1.作用:路由組件所獨有的兩個鉤子,用于捕獲路由組件的激活狀態(tài)分別是activated 路由組件被激活時觸發(fā)。deactivated 路由組件失活時觸發(fā)。

6.路由守衛(wèi)

作用:對路由進行權(quán)限控制

分類:全局守衛(wèi)、獨享守衛(wèi)、組件內(nèi)守衛(wèi)

1.全局守衛(wèi)

router.beforeEach((to, from, next) => {
    console.log(to, from);
    if (to.meta.isAuth) {//判斷是否需要鑒權(quán)
        if (localStorage.getItem('school') ==='shanyu') {
            next();
        } else {
            alert('該學(xué)校無權(quán)限查看此內(nèi)容')
        }
    } else {
        next()
    }
})
// 后置路由守衛(wèi),切換路由后調(diào)用
router.afterEach((to, from) => {
    console.log(to, from);
    document.title=to.meta.title||'山魚屋'
})

2.獨享路由守衛(wèi)

專門服務(wù)于一個路由的守衛(wèi)

beforeEnter: (to, from, next) => {
                        console.log(to, from);
                        if (to.meta.isAuth) { //判斷是否需要鑒權(quán)
                            if (localStorage.getItem('school') ==='shanyu') {
                                next();
                            } else {
                                alert('該學(xué)校無權(quán)限查看此內(nèi)容')
                            }
                        } else {
                            next()
                        }
                    },

3.組件內(nèi)守衛(wèi)

在進入/離開組件時被激活

//進入守衛(wèi):通過路由規(guī)則,進入該組件時被調(diào)用
beforeRouteEnter (to, from, next) {
},
//離開守衛(wèi):通過路由規(guī)則,離開該組件時被調(diào)用
beforeRouteLeave (to, from, next) {
?}

4.路由器的兩種工作模式

對于一個url來說#其后面的內(nèi)容就是hash值。

就是這個#后面的

hash的特點及使用

1.hash值不會帶給服務(wù)器。

2.hash模式

  • 1.地址中永遠帶著#號
  • 2.若以后將地址通過第三方手機app分享,若app校驗嚴格, 則地址會被標記為不合法。
  • 3.兼容性較好。

3.history模式

  • 1.地址干凈,美觀。
  • 2.兼容性和hash模式相比略差。
  • 3. 應(yīng)用部署上線時需要后端人員支持,解決刷新頁面服務(wù)端404的問題。

4.切換history模式

在route文件夾下面的index文件里添加 `mode: 'history'`這句代碼即可(默認的是hash模式)

寫在最后

到此這篇關(guān)于Vue中的路由與多種守衛(wèi)的文章就介紹到這了,更多相關(guān)Vue路由守衛(wèi)內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • 淺析Vue中渲染函數(shù)的使用

    淺析Vue中渲染函數(shù)的使用

    在Vue中,渲染函數(shù)是一種用于動態(tài)生成組件的函數(shù),可以將組件的模板代碼編寫為JavaScript代碼,并在運行時進行渲染,下面我們就來看看它的具體用法吧
    2023-08-08
  • vue自定義指令限制輸入框輸入值的步驟與完整代碼

    vue自定義指令限制輸入框輸入值的步驟與完整代碼

    這篇文章主要給大家介紹了關(guān)于vue自定義指令限制輸入框輸入值的相關(guān)資料,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習或者工作具有一定的參考學(xué)習價值,需要的朋友們下面隨著小編來一起學(xué)習學(xué)習吧
    2020-08-08
  • vue2.0數(shù)據(jù)雙向綁定與表單bootstrap+vue組件

    vue2.0數(shù)據(jù)雙向綁定與表單bootstrap+vue組件

    這篇文章主要介紹了vue2.0數(shù)據(jù)雙向綁定與表單bootstrap+vue組件,非常不錯,具有參考借鑒價值,需要的朋友可以參考下
    2017-02-02
  • Vue的自定義事件之組件通信工具詳解

    Vue的自定義事件之組件通信工具詳解

    這篇文章主要介紹了Vue的自定義事件之組件通信工具詳解,Vue的自定義事件(Custom Events)是一種強大的工具,用于實現(xiàn)組件之間的通信和數(shù)據(jù)傳遞,本文將深入探討什么是Vue的自定義事件,以及如何自定義和使用它們,需要的朋友可以參考下
    2023-10-10
  • Vue.js中v-for指令的用法介紹

    Vue.js中v-for指令的用法介紹

    這篇文章介紹了Vue.js中v-for指令的用法,文中通過示例代碼介紹的非常詳細。對大家的學(xué)習或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2022-03-03
  • vue如何關(guān)閉eslint檢測(多種方法)

    vue如何關(guān)閉eslint檢測(多種方法)

    我們在開發(fā)vue項目的時候,創(chuàng)建的時候可能會不小心選擇了eslint,所以如果不想讓eslint檢測,我們該怎么辦呢,本文就詳細的介紹了幾種關(guān)閉方法,感興趣的可以了解一下
    2021-12-12
  • 快速搭建vue2.0+boostrap項目的方法

    快速搭建vue2.0+boostrap項目的方法

    這篇文章主要介紹了快速搭建vue2.0+boostrap項目的方法,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2018-04-04
  • Vue實現(xiàn)點擊圖片放大顯示功能

    Vue實現(xiàn)點擊圖片放大顯示功能

    這篇文章主要為大家詳細介紹了如何利用Vue實現(xiàn)點擊圖片放大顯示功能,文中的示例代碼講解詳細,具有一定的參考價值,感興趣的可以了解一下
    2023-03-03
  • 詳解el-table表頭文字換行的三種方式

    詳解el-table表頭文字換行的三種方式

    本文主要介紹了el-table表頭文字換行的三種方式,文中通過示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2021-11-11
  • vue3如何實現(xiàn)變量雙向綁定

    vue3如何實現(xiàn)變量雙向綁定

    這篇文章主要介紹了vue3如何實現(xiàn)變量雙向綁定問題,具有很好的參考價值,希望對大家有所幫助,
    2023-11-11

最新評論