詳解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.什么是路由
一個路由就是一組映射關(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)文章
vue2.0數(shù)據(jù)雙向綁定與表單bootstrap+vue組件
這篇文章主要介紹了vue2.0數(shù)據(jù)雙向綁定與表單bootstrap+vue組件,非常不錯,具有參考借鑒價值,需要的朋友可以參考下2017-02-02