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