詳解Vue中的路由與多種守衛(wèi)
什么是路由呢?
路由其實(shí)是一種映射關(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)路由,路由獨(dú)享。
全局路由鉤子函數(shù)有:beforeEach、beforeResolve、afterEach(參數(shù)中沒有next)
組件內(nèi)路由的鉤子函數(shù)有:beforeRouterEnter、beforeRouteUpdate、beforeRouteLeave
路由獨(dú)享的鉤子函數(shù)有:beforeEnter

1.vue-router
vue的一個插件庫,專門用來實(shí)現(xiàn)對SPA應(yīng)用的單頁Web應(yīng)用(single page web application, SPA)。整個應(yīng)用只有一個完整的頁面。點(diǎn)擊頁面中的導(dǎo)航鏈接不會刷新頁面,只會做頁面的局部更新。數(shù)據(jù)需要通過ajax請求獲取。
2.什么是路由
一個路由就是一組映射關(guān)系(key :value)
key 為路徑, value可能是function或componente
路由分類
1.后端路由:value 杲function,用于處理客戶端提交的請求。工作過程: 服務(wù)器接收到一個請求時,根據(jù)請求路徑找到匹配的函數(shù)來處理請求,返回響應(yīng)數(shù)據(jù)。
2.前端路由: value是component,用于展示頁面內(nèi)容。工作過程: 當(dāng)瀏覽器的路徑改變時,對應(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實(shí)現(xiàn)切換(注:router-link經(jīng)過瀏覽器后就會變成a標(biāo)簽哦)
<divclass="list-group">
<!-- 原始寫法——使用a標(biāo)簽進(jìn)行頁面的跳轉(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提供的標(biāo)簽進(jìn)行路徑的修改,實(shí)現(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實(shí)現(xiàn)組件的呈現(xiàn)(類似于插槽)
<divclass="panel-body">
<!-- 指定組件的呈現(xiàn)位置 -->
<router-view>
</router-view>
</div>注:1.路由組件通常存放在pages文件夾,所以不要往components文件夾里面放了
2.通過切換,“隱藏” 了的路由組件,默認(rèn)是被銷毀掉的,需要的時候再去掛載
3.每個組件都有自己的$route屬性,里面存儲著自己的路由信息。
4.整個應(yīng)用只有一個router, 可以通過組件的$router屬性獲取到。
4.多級路由
在配置路由規(guī)則的以及路由里面進(jìn)行配置下一級路由使用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 是替換當(dāng)前記錄。路由跳轉(zhuǎn)時候默認(rèn)為push,所以為push的時候可以進(jìn)行后退前進(jìn)操作,而replace直接就是替換掉之前的那個地址所以在replace的里面智慧存在一個地址,也就是當(dāng)前所呈現(xiàn)的那個地址,就好比做核算,push是排隊的人,replace是做核酸的醫(yī)務(wù)人員
3.如何開啟replace模式:<router-link replace ...... >News</router- link>即可

4.編程式路由導(dǎo)航
1.作用:不借助<router- link>實(shí)現(xiàn)路由跳轉(zhuǎn),讓路由跳轉(zhuǎn)更加靈活
methods: {
//后退
back() {
this.$router.back();
},
//前進(jìn)
forward() {
this.$router.forward();
},
//可以后退也可以前進(jìn)
test() {
this.$router.go(-2);
}
}5.緩存路由組件
1.作用:讓不展示的路由組件保持掛載,不被銷毀。
2.具體實(shí)現(xiàn)方法
<keep-alivelinclude= "News"> K router-view></router-view> </keep-alive>
兩個新的生命周期鉤子
1.作用:路由組件所獨(dú)有的兩個鉤子,用于捕獲路由組件的激活狀態(tài)分別是activated 路由組件被激活時觸發(fā)。deactivated 路由組件失活時觸發(fā)。
6.路由守衛(wèi)
作用:對路由進(jìn)行權(quán)限控制
分類:全局守衛(wèi)、獨(dú)享守衛(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.獨(dú)享路由守衛(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)
在進(jìn)入/離開組件時被激活
//進(jìn)入守衛(wèi):通過路由規(guī)則,進(jìn)入該組件時被調(diào)用
beforeRouteEnter (to, from, next) {
},
//離開守衛(wèi):通過路由規(guī)則,離開該組件時被調(diào)用
beforeRouteLeave (to, from, next) {
?}4.路由器的兩種工作模式
對于一個url來說#其后面的內(nèi)容就是hash值。

就是這個#后面的
hash的特點(diǎn)及使用
1.hash值不會帶給服務(wù)器。
2.hash模式
- 1.地址中永遠(yuǎn)帶著#號
- 2.若以后將地址通過第三方手機(jī)app分享,若app校驗嚴(yán)格, 則地址會被標(biāo)記為不合法。
- 3.兼容性較好。
3.history模式
- 1.地址干凈,美觀。
- 2.兼容性和hash模式相比略差。
- 3. 應(yīng)用部署上線時需要后端人員支持,解決刷新頁面服務(wù)端404的問題。
4.切換history模式

在route文件夾下面的index文件里添加 `mode: 'history'`這句代碼即可(默認(rèn)的是hash模式)
寫在最后
到此這篇關(guān)于Vue中的路由與多種守衛(wèi)的文章就介紹到這了,更多相關(guān)Vue路由守衛(wèi)內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
vue2.0數(shù)據(jù)雙向綁定與表單bootstrap+vue組件
這篇文章主要介紹了vue2.0數(shù)據(jù)雙向綁定與表單bootstrap+vue組件,非常不錯,具有參考借鑒價值,需要的朋友可以參考下2017-02-02
Vue實(shí)現(xiàn)點(diǎn)擊圖片放大顯示功能
這篇文章主要為大家詳細(xì)介紹了如何利用Vue實(shí)現(xiàn)點(diǎn)擊圖片放大顯示功能,文中的示例代碼講解詳細(xì),具有一定的參考價值,感興趣的可以了解一下2023-03-03

