溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶服務(wù)條款》

vue-router 2.0 常用基礎(chǔ)知識(shí)點(diǎn)之router-link的示例分析

發(fā)布時(shí)間:2021-07-22 15:51:31 來(lái)源:億速云 閱讀:156 作者:小新 欄目:web開(kāi)發(fā)

這篇文章給大家分享的是有關(guān)vue-router 2.0 常用基礎(chǔ)知識(shí)點(diǎn)之router-link的示例分析的內(nèi)容。小編覺(jué)得挺實(shí)用的,因此分享給大家做個(gè)參考,一起跟隨小編過(guò)來(lái)看看吧。

1,$route.params

類型: Object

一個(gè) key/value 對(duì)象,包含了 動(dòng)態(tài)片段 和 全匹配片段,如果沒(méi)有路由參數(shù),就是一個(gè)空對(duì)象。

path: '/detail/:id' 動(dòng)態(tài)路徑參數(shù) 以冒號(hào)開(kāi)頭

const routes = [
 {path: '/detail/:id', component: Detail, name: 'detail', meta: {title: ''}},
 {path: '/activity', component: Activity, name: 'activity', meta: {isNeedAuth: false, title: '活動(dòng)現(xiàn)場(chǎng)'}},
];

還可以在一個(gè)路由中設(shè)置多段『路徑參數(shù)』,對(duì)應(yīng)的值都會(huì)設(shè)置到 $route.params 中

1個(gè)參數(shù)

模式: /user/:username

匹配路徑: /user/evan

$route.params:{ username: 'evan' }

多個(gè)參數(shù)

模式: /user/:username/post/:post_id

匹配路徑:/user/evan/post/123

$route.params:{ username: 'evan', post_id: 123 }

復(fù)用組件時(shí),想對(duì)路由參數(shù)的變化作出響應(yīng)的話,你可以簡(jiǎn)單地 watch(監(jiān)測(cè)變化) $route 對(duì)象:

const User = {
 template: '...',
 watch: {
 '$route' (to, from) {
  // 對(duì)路由變化作出響應(yīng)...
 }
 }
}

或者像下面這樣,只要$route發(fā)生變化,就可以做某事:

export default {
 data () {
 return {}
 },
 watch: {
 // 如果路由有變化,會(huì)再次執(zhí)行該方法
 '$route': 'doSomeThing'
 },
 methods: {
 doSomeThing(){}
 }
}

綜合案例

// 當(dāng)匹配到一個(gè)路由時(shí),參數(shù)值會(huì)被設(shè)置到 this.$route.params,可以在每個(gè)組件內(nèi)使用。
// 可以通過(guò)this.$route.params.id來(lái)取上動(dòng)態(tài)的id
<router-link :to="{path: '/detail/' + this.$route.params.id}" >
此團(tuán)詳情
</router-link>

// 還可以用命名路由的方式:
<router-link :to="{ name: 'detail', params:{ id: this.$route.params.id }}" >
此團(tuán)詳情
</router-link>

// 還可以用router.push()的方式
router.push({name:'detail', params: { id: this.$route.params.id}})

// 以上三種方式都可以實(shí)現(xiàn)跳轉(zhuǎn),都可以通過(guò)this.$route.params來(lái)取到參數(shù)

2,$route.query

類型: Object

一個(gè) key/value 對(duì)象,表示 URL 查詢參數(shù)。例如,對(duì)于路徑 /foo?user=1,則有 $route.query.user == 1,如果沒(méi)有查詢參數(shù),則是個(gè)空對(duì)象。

// 動(dòng)態(tài)數(shù)據(jù)的查詢參數(shù)
 export default {
  data() {
   return {
    queryData: {}
   }
  },
  created() {
   this.$http.get(url)
    .then(function (response) {
     // ...
     if (data.code == 0) {
      this.queryData.order_id = data.content.order_id;
      this.queryData.business_id = data.content.business_id;
      this.queryData.coupon_id = data.content.coupons.coupon_id;
     }
     // ...
    }, function (response) {
     // ...
    })
  },
 }

// 使用
<router-link :to="{ path: '/backend/verify_coupon', query:this.queryData }">驗(yàn)證抵扣券</router-link>

3,定義路由的時(shí)候可以配置 meta 字段

// 舉個(gè)例子
const routes = [
 {path: '/activity', component: Activity, name: 'activity', meta: {isNeedAuth: false, title: '活動(dòng)現(xiàn)場(chǎng)'}},
];

實(shí)際工作中使用的時(shí)候就可以像下面這樣:

import { setTitleHack } from './utils';
import Activity from './views/activity.vue'
import Start from './views/start.vue'
// 定義路由的時(shí)候在meta中加入自定義字段
const routes = [
 {path: '/activity', component: Activity, name: 'activity', meta: {isNeedAuth: false, title: '活動(dòng)現(xiàn)場(chǎng)'}},
 {path: '/start', component: Start, name: 'start', meta: {isNeedAuth: false, title: '活動(dòng)現(xiàn)場(chǎng)'}},
];
const router = new VueRouter({...});
router.beforeEach((to, from, next) => {
 // 動(dòng)態(tài)修改頁(yè)面的title
 setTitleHack(to.meta.title);
  // 根據(jù)自定義的路由元信息來(lái)做判斷:
 if (to.meta.isNeedAuth !== false) {
  // do something
 } else {
  // do something
 }
 next();
});

4,append

設(shè)置 append 屬性后,則在當(dāng)前(相對(duì))路徑前添加基路徑。例如,我們從 /a 導(dǎo)航到一個(gè)相對(duì)路徑 b,如果沒(méi)有配置 append,則路徑為 /b,如果配了,則為 /a/b

復(fù)制代碼 代碼如下:


<router-link :to="{path:'/coupon/detail/'+item.order_id, append:'true'}"></router-link>

如果上面這個(gè)路由是從home頁(yè)面跳轉(zhuǎn)過(guò)來(lái),得到的結(jié)果就是/home/coupon/detail/id

5,active-class

類型: string

默認(rèn)值: "router-link-active"

設(shè)置 鏈接激活時(shí)使用的 CSS 類名。默認(rèn)值可以通過(guò)路由的構(gòu)造選項(xiàng) linkActiveClass 來(lái)全局配置。

復(fù)制代碼 代碼如下:


<router-link tag="li" :to="{path:'/home', activeClass: 'bottom-nav-active'}"></router-link>

7,綜合案例

// 命名路由,append 屬性,查詢參數(shù),router-link渲染成<li>標(biāo)簽
<router-link tag="li" :to="{name:'demandindex', append:true, query: {isFormBackend: 1}, activeClass: 'bottom-nav-active'}">
</router-link>

// to的值:字符串形式
<router-link to="banner.image_url" ></router-link>

// to的值:對(duì)象形式,拼接多個(gè)動(dòng)態(tài)參數(shù)
<router-link :to="{path: '/my/modify?modify=fullname&val=' + profile.nickname}" ></router-link>

// to的值:對(duì)象形式
<router-link :to="{path: '/home'}">返回首頁(yè)</router-link>

// to的值:對(duì)象形式,拼接動(dòng)態(tài)參數(shù)
<router-link to="{path: '/backend/coupon_order_detail/' + product.order_id+'?order_status='+product.order_status}"></router-link>

// to的值:對(duì)象形式,帶一個(gè)路徑參數(shù)
<router-link :to="{path: '/detail/' + this.$route.params.id}" ></router-link>

感謝各位的閱讀!關(guān)于“vue-router 2.0 常用基礎(chǔ)知識(shí)點(diǎn)之router-link的示例分析”這篇文章就分享到這里了,希望以上內(nèi)容可以對(duì)大家有一定的幫助,讓大家可以學(xué)到更多知識(shí),如果覺(jué)得文章不錯(cuò),可以把它分享出去讓更多的人看到吧!

向AI問(wèn)一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI