Vue--Router動(dòng)態(tài)路由的用法示例詳解
本文介紹Vue-Router中動(dòng)態(tài)路由的用法。
官網(wǎng)網(wǎng)址
Vue官網(wǎng):帶參數(shù)的動(dòng)態(tài)路由匹配 | Vue Router
動(dòng)態(tài)路由概述
說(shuō)明
很多時(shí)候,我們需要將給定匹配模式的路由映射到同一個(gè)組件。例如,我們可能有一個(gè) User 組件,它應(yīng)該對(duì)所有用戶(hù)進(jìn)行渲染,但用戶(hù) ID 不同。在 Vue Router 中,我們可以在路徑中使用一個(gè)動(dòng)態(tài)字段來(lái)實(shí)現(xiàn),我們稱(chēng)之為 路徑參數(shù) 。
路徑參數(shù) 用冒號(hào)(:) 表示。當(dāng)一個(gè)路由被匹配時(shí),它的 params 的值將在每個(gè)組件中以 this.$route.params 的形式暴露出來(lái)。
示例
const User = { template: '<div>User</div>', } // 這些都會(huì)傳遞給 `createRouter` const routes = [ // 動(dòng)態(tài)字段以冒號(hào)開(kāi)始 { path: '/users/:id', component: User }, ]
現(xiàn)在像 /users/johnny 和 /users/jolyne 這樣的 URL 都會(huì)映射到同一個(gè)路由??梢酝ㄟ^(guò)更新 User 的模板來(lái)呈現(xiàn)當(dāng)前的用戶(hù) ID:
const User = { template: '<div>User {{ $route.params.id }}</div>', }
同一路由多個(gè)參數(shù)
可以在同一個(gè)路由中設(shè)置有多個(gè) 路徑參數(shù),它們會(huì)映射到 $route.params 上的相應(yīng)字段。
例如:
匹配模式 | 匹配路徑 | $route.params |
/users/:username | /users/eduardo | { username: 'eduardo' } |
/users/:username/posts/:postId | /users/eduardo/posts/123 | { username: 'eduardo', postId: '123' } |
path-to-regexp
簡(jiǎn)介
說(shuō)明
vue-router底層是通過(guò)path-to-regexp來(lái)實(shí)現(xiàn)的路徑參數(shù)。
該工具庫(kù)用來(lái)處理 url 中地址與參數(shù),能夠很方便得到我們想要的數(shù)據(jù)。
js 中有 RegExp 方法做正則表達(dá)式校驗(yàn),而 path-to-regexp 可以看成是 url 字符串的正則表達(dá)式。
官網(wǎng)網(wǎng)址
github:GitHub - pillarjs/path-to-regexp at v1.7.0
github用法翻譯:path-to-regexp介紹
在線測(cè)試:Express Route Tester
Api用法
npm install path-to-regexp const pathToRegexp = require('path-to-regexp');
1. pathToRegexp()
作用:這里這個(gè)方法可以類(lèi)比于 js 中 new ExpReg('xxx')。
var pathToRegexp = require('path-to-regexp') var re = pathToRegexp('/foo/:bar') console.log(re); // /^\/foo\/((?:[^\/]+?))(?:\/(?=$))?$/i
2、exec()
作用:匹配 url 地址與規(guī)則是否相符。
url路徑與匹配規(guī)則不相符返回 null, 與匹配規(guī)則相符,返回一個(gè)數(shù)組。
var pathToRegexp = require('path-to-regexp') var re = pathToRegexp('/foo/:bar'); // 匹配規(guī)則 var match1 = re.exec('/test/route'); // url 路徑 var match2 = re.exec('/foo/route'); // url 路徑 console.log(match1); //null console.log(match2); //[ '/foo/route', 'route', index: 0, input: '/foo/route' ]
3. parse()
作用:解析 url 字符串中的參數(shù)部分(:id)
返回一個(gè)數(shù)組,可得到 url 地址攜帶參數(shù)的屬性名稱(chēng)(item.name)。
url 中攜帶參數(shù)出了 :id 這種形式,還有 /user?id=11 這種,使用 parse() 方法解析自行查看結(jié)果
var pathToRegexp = require('path-to-regexp'); var url = '/user/:id'; console.log(pathToRegexp.parse(url)); //[ '/user',{ name: 'id', prefix: '/',delimiter: '/',optional: false, repeat: false, partial: false, pattern: '[^\\/]+?' } ]
4. compile()
作用:快速填充 url 字符串的參數(shù)值。
var pathToRegexp = require('path-to-regexp') var url = '/user/:id/:name' var data = {id: 10001, name: 'bob'} console.log(pathToRegexp.compile(url)(data)); // /user/10001/bob
到此這篇關(guān)于Vue--Router動(dòng)態(tài)路由的用法的文章就介紹到這了,更多相關(guān)VueRouter動(dòng)態(tài)路由內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
vue中實(shí)現(xiàn)圖片壓縮 file文件的方法
這篇文章主要介紹了vue中實(shí)現(xiàn)圖片壓縮 file文件的方法,本文通過(guò)實(shí)例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2020-05-05iview table render集成switch開(kāi)關(guān)的實(shí)例
下面小編就為大家分享一篇iview table render集成switch開(kāi)關(guān)的實(shí)例,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2018-03-03vue學(xué)習(xí)筆記之過(guò)濾器的基本使用方法實(shí)例分析
這篇文章主要介紹了vue學(xué)習(xí)筆記之過(guò)濾器的基本使用方法,結(jié)合實(shí)例形式分析了vue.js過(guò)濾器的基本功能、用法與操作注意事項(xiàng),需要的朋友可以參考下2020-02-02vue3+ts+element-plus實(shí)際開(kāi)發(fā)之統(tǒng)一調(diào)用彈窗封裝的詳細(xì)過(guò)程
這篇文章主要介紹了vue3+ts+element-plus實(shí)際開(kāi)發(fā)之統(tǒng)一調(diào)用彈窗封裝的詳細(xì)過(guò)程,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友參考下吧2024-03-03Vue自定義指令實(shí)現(xiàn)彈窗拖拽四邊拉伸及對(duì)角線拉伸效果
小編最近在做一個(gè)vue前端項(xiàng)目,需要實(shí)現(xiàn)彈窗的拖拽,四邊拉伸及對(duì)角線拉伸,以及彈窗邊界處理功能,本文通過(guò)實(shí)例代碼給大家分享我的實(shí)現(xiàn)過(guò)程及遇到問(wèn)題解決方法,感興趣的朋友一起看看吧2021-08-08vue.js 實(shí)現(xiàn)v-model與{{}}指令方法
這篇文章主要介紹了vue.js 實(shí)現(xiàn)v-model與{{}}指令方法,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2018-10-10