欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Vue--Router動態(tài)路由的用法示例詳解

 更新時間:2022年08月05日 10:33:46   作者:IT利刃出鞘  
這篇文章主要介紹了Vue--Router動態(tài)路由的用法,很多時候,我們需要將給定匹配模式的路由映射到同一個組件,在?Vue?Router?中,我們可以在路徑中使用一個動態(tài)字段來實現(xiàn),我們稱之為路徑參數(shù),本文對Vue?Router動態(tài)路由相關(guān)知識給大家介紹的非常詳細(xì),需要的朋友參考下吧

本文介紹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)文章

  • vue中實現(xiàn)圖片壓縮 file文件的方法

    vue中實現(xiàn)圖片壓縮 file文件的方法

    這篇文章主要介紹了vue中實現(xiàn)圖片壓縮 file文件的方法,本文通過實例代碼給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2020-05-05
  • 詳解在Vue中通過自定義指令獲取dom元素

    詳解在Vue中通過自定義指令獲取dom元素

    本篇文章主要介紹了詳解在Vue中通過自定義指令獲取dom元素 ,具有一定的參考價值,有興趣的可以了解一下。
    2017-03-03
  • iview table render集成switch開關(guān)的實例

    iview table render集成switch開關(guān)的實例

    下面小編就為大家分享一篇iview table render集成switch開關(guān)的實例,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2018-03-03
  • vue-cli腳手架引入彈出層layer插件的幾種方法

    vue-cli腳手架引入彈出層layer插件的幾種方法

    layer.js(mobile)是一個小巧方便的彈出層插件,在之前的apicloud項目中被大量使用,但最近對apicloud的IDE、非常不友好的文檔和極低的開發(fā)效率深感厭煩,決定棄用然后轉(zhuǎn)向Vue開發(fā)。這篇文章主要介紹了vue-cli腳手架引入彈出層layer插件的幾種方法,需要的朋友可以參考下
    2019-06-06
  • 全局引入vant后使用Toast的問題及解決

    全局引入vant后使用Toast的問題及解決

    這篇文章主要介紹了全局引入vant后使用Toast的問題及解決,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-05-05
  • vue學(xué)習(xí)筆記之過濾器的基本使用方法實例分析

    vue學(xué)習(xí)筆記之過濾器的基本使用方法實例分析

    這篇文章主要介紹了vue學(xué)習(xí)筆記之過濾器的基本使用方法,結(jié)合實例形式分析了vue.js過濾器的基本功能、用法與操作注意事項,需要的朋友可以參考下
    2020-02-02
  • vue3+ts+element-plus實際開發(fā)之統(tǒng)一調(diào)用彈窗封裝的詳細(xì)過程

    vue3+ts+element-plus實際開發(fā)之統(tǒng)一調(diào)用彈窗封裝的詳細(xì)過程

    這篇文章主要介紹了vue3+ts+element-plus實際開發(fā)之統(tǒng)一調(diào)用彈窗封裝的詳細(xì)過程,本文給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友參考下吧
    2024-03-03
  • vue3獲取當(dāng)前路由地址

    vue3獲取當(dāng)前路由地址

    本文詳細(xì)講解了vue3獲取當(dāng)前路由地址的方法,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2022-01-01
  • Vue自定義指令實現(xiàn)彈窗拖拽四邊拉伸及對角線拉伸效果

    Vue自定義指令實現(xiàn)彈窗拖拽四邊拉伸及對角線拉伸效果

    小編最近在做一個vue前端項目,需要實現(xiàn)彈窗的拖拽,四邊拉伸及對角線拉伸,以及彈窗邊界處理功能,本文通過實例代碼給大家分享我的實現(xiàn)過程及遇到問題解決方法,感興趣的朋友一起看看吧
    2021-08-08
  • vue.js 實現(xiàn)v-model與{{}}指令方法

    vue.js 實現(xiàn)v-model與{{}}指令方法

    這篇文章主要介紹了vue.js 實現(xiàn)v-model與{{}}指令方法,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2018-10-10

最新評論