国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > JavaScript > 正文

vue-router傳遞參數(shù)的幾種方式實例詳解

2019-11-19 12:31:48
字體:
供稿:網(wǎng)友

vue-router傳遞參數(shù)分為兩大類

  • 編程式的導(dǎo)航 router.push
  • 聲明式的導(dǎo)航 <router-link>

編程式的導(dǎo)航 router.push

編程式導(dǎo)航傳遞參數(shù)有兩種類型:字符串、對象。

字符串

字符串的方式是直接將路由地址以字符串的方式來跳轉(zhuǎn),這種方式很簡單但是不能傳遞參數(shù):

this.$router.push("home");

對象

想要傳遞參數(shù)主要就是以對象的方式來寫,分為兩種方式:命名路由、查詢參數(shù),下面分別說明兩種方式的用法和注意事項。

命名路由

命名路由的前提就是在注冊路由的地方需要給路由命名如:

命名路由傳遞參數(shù)需要使用params來傳遞,這里一定要注意使用params不是query。

目標(biāo)頁面接收傳遞參數(shù)時使用params

特別注意:命名路由這種方式傳遞的參數(shù),如果在目標(biāo)頁面刷新是會出錯的

使用方法如下:

this.$router.push({ name: 'news', params: { userId: 123 }})

代碼如下:

<template> <div class="hello">  <h1>{{ msg }}</h1>  <button @click="routerTo">click here to news page</button> </div></template><script>export default { name: 'HelloWorld', data () {  return {   msg: 'Welcome to Your Vue.js App'  } }, methods:{  routerTo(){   this.$router.push({ name: 'news', params: { userId: 123 }});  } }}</script><style></style>接受傳遞的參數(shù):<template> <div>  this is the news page.the transform param is {{this.$route.params.userId}} </div></template><script></script>

運(yùn)行效果如下:

查詢參數(shù)

查詢參數(shù)其實就是在路由地址后面帶上參數(shù)和傳統(tǒng)的url參數(shù)一致的,傳遞參數(shù)使用query而且必須配合path來傳遞參數(shù)而不能用name,目標(biāo)頁面接收傳遞的參數(shù)使用query。

注意:和name配對的是params,和path配對的是query

使用方法如下:

this.$router.push({ path: '/news', query: { userId: 123 }});代碼如下:<template> <div class="hello">  <h1>{{ msg }}</h1>  <button @click="routerTo">click here to news page</button> </div></template><script>export default { name: 'HelloWorld', data () {  return {   msg: 'Welcome to Your Vue.js App'  } }, methods:{  routerTo(){   this.$router.push({ path: '/news', query: { userId: 123 }});  } }}</script><style></style>接收參數(shù)如下:<template> <div>  this is the news page.the transform param is {{this.$route.query.userId}} </div></template><script></script>

運(yùn)行效果如下:

聲明式的導(dǎo)航

聲明式的導(dǎo)航和編程式的一樣,這里就不在過多介紹,給幾個例子大家對照編程式理解,

例子如下:

字符串

<router-link to="news">click to news page</router-link>

命名路由

<router-link :to="{ name: 'news', params: { userId: 1111}}">click to news page</router-link>

運(yùn)行效果如下:

查詢參數(shù)

<router-link :to="{ path: '/news', query: { userId: 1111}}">click to news page</router-link>

運(yùn)行效果如下:

最后總結(jié):

路由傳遞參數(shù)和傳統(tǒng)傳遞參數(shù)是一樣的,命名路由類似表單提交而查詢就是url傳遞,在vue項目中基本上掌握了這兩種傳遞參數(shù)就能應(yīng)付大部分應(yīng)用了,最后總結(jié)為以下兩點(diǎn):

1.命名路由搭配params,刷新頁面參數(shù)會丟失

2.查詢參數(shù)搭配query,刷新頁面數(shù)據(jù)不會丟失

3.接受參數(shù)使用this.$router后面就是搭配路由的名稱就能獲取到參數(shù)的值

總結(jié)

以上所述是小編給大家介紹的vue-router傳遞參數(shù)的幾種方式實例詳解,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復(fù)大家的。在此也非常感謝大家對武林網(wǎng)網(wǎng)站的支持!

發(fā)表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發(fā)表
主站蜘蛛池模板: 都江堰市| 南江县| 台湾省| 北辰区| 罗山县| 寻甸| 永新县| 五河县| 普洱| 新营市| 新余市| 阿瓦提县| 田阳县| 贡觉县| 泸溪县| 利川市| 宁德市| 桦甸市| 潼南县| 孙吴县| 桑日县| 武安市| 千阳县| 高邮市| 潼关县| 腾冲县| 麦盖提县| 右玉县| 调兵山市| 咸丰县| 永济市| 玛沁县| 武鸣县| 滕州市| 瓦房店市| 台北市| 玛多县| 曲阳县| 汉川市| 改则县| 温泉县|