上一篇主要寫了一下vuer-router的基本使用,可以說解決溫飽了,下面就再來點下午茶吧
創(chuàng)新互聯(lián)是一家專業(yè)提供尤溪企業(yè)網(wǎng)站建設,專注與成都網(wǎng)站設計、做網(wǎng)站、HTML5、小程序制作等業(yè)務。10年已為尤溪眾多企業(yè)、政府機構等服務。創(chuàng)新互聯(lián)專業(yè)網(wǎng)站設計公司優(yōu)惠進行中。
模式
vue-router中的模式選項主要在router實例化的時候進行定義的,如下
const router = new VueRouter({ mode: 'history', // 兩種類型history 還有 hash routes: routes // 可以縮寫成routes })
有兩種模式可供選擇,history 和 hash,大致對比一下,
模式 | 優(yōu)點 | 缺點 |
---|---|---|
hash | 使用簡單、無需后臺支持 | 在url中以hash形式存在,不會傳到后臺 |
history | 地址明確,便于理解和后臺處理 | 需要后臺配合 |
hash模式對于后臺來講就是一個url,因為地址中的hash值是不會傳到后臺的,所以服務器端做一個根地址的映射就可以了。
history模式最終的路由都體現(xiàn)在url的pathname中,這部分是會傳到服務器端的,因此需要服務端對每一個可能的path值都作相應的映射?;蛘卟捎媚:ヅ涞姆绞竭M行映射。
除此之外,history模式下,如果后端不是一對一的進行映射,而是模糊匹配的話,那么就要注意一下404的情況了。這個時候就需要在前端router中定義404頁面了。
404路由的定義
由于router本身的匹配是從上到下的,如果在前面找到了匹配的路由,就跳轉了。因此可以直接在最后添加404的路由,如下
let routerConfig = [{ path: '/pages', component: App, children: [{ path: 'demo/step1/list', component: coupon, name: 'coupon-list', meta: { title: '紅包' } }] }, { path: '*', component: NotFound, name: 'notfound', meta: { title: '404-頁面丟了' } }]
在前面匹配不到的時候,* 代表全部,就是都指向404頁面
路由鉤子
路由鉤子主要是給使用者在路由發(fā)生變化時進行一些特殊的處理而定義的,靠。。好拗口啊。
總體來講vue里面提供了三大類鉤子
1、全局鉤子
2、某個路由獨享的鉤子
3、組件內(nèi)鉤子
全局鉤子
顧名思義,全局鉤子全局用,使用如下
const router = new VueRouter({ mode: 'history', base: __dirname, routes: routerConfig }) router.beforeEach((to, from, next) => { document.title = to.meta.title || 'demo' if (!to.query.url && from.query.url) { to.query.url = from.query.url } next() }) router.afterEach(route => { })
某個路由獨享鉤子
就像說的一樣,給某個路由單獨使用的,本質上和后面的組件內(nèi)鉤子是一樣的。都是特指的某個路由。不同的是,這里的一般定義在router當中,而不是在組件內(nèi)。如下
const router = new VueRouter({ routes: [ { path: '/foo', component: Foo, beforeEnter: (to, from, next) => { // ... }, beforeLeave: (to, from, next) => { // ... } } ] })
組件內(nèi)鉤子
首先看一下官方定義:
你可以在路由組件內(nèi)直接定義以下路由導航鉤子
路由組件!路由組件!路由組件!重要的事情說三遍,大家一定要注意這里說的是“路由組件”,而路由組件!== 組件,路由組件!== 組件,路由組件!== 組件!之前一直沒注意這點,然后在子組件里面傻乎乎的調(diào)鉤子函數(shù)發(fā)現(xiàn)一直沒用。。。
我們先來看一下什么是路由組件?
路由組件:直接定義在router中component處的組件
也就是說router中定義的入口vue文件之外的組件,是沒有鉤子函數(shù)的,也就不用說使用了。但是如果你使用了并不會報錯,只是沒反應。(本想畫個圖的,太懶了。。。自己理解理解吧,很好理解的)
這里再回頭看下這個路由內(nèi)鉤子是怎么用的,很簡單和data、method平級的方法
beforeRouteLeave(to, from, next) { // .... next() }, beforeRouteEnter(to, from, next) { // .... next() }, beforeRouteUpdate(to, from, next) { // .... next() }, computed: {}, method: {}
三種路由鉤子中都涉及到了三個參數(shù),這里直接上官方介紹吧
模式和鉤子基本就到這了,有需要的可以在仔細研究一個官當?shù)奈臋n。以上僅是個人學習使用過程的一些理解,希望對大家的學習有所幫助,也希望大家多多支持創(chuàng)新互聯(lián)。