中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

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

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

vue-router中參數傳遞的方式有哪些

發布時間:2021-06-15 16:56:22 來源:億速云 閱讀:163 作者:Leah 欄目:web開發

今天就跟大家聊聊有關vue-router中參數傳遞的方式有哪些,可能很多人都不太了解,為了讓大家更加了解,小編給大家總結了以下內容,希望大家根據這篇文章可以有所收獲。

vue-router傳遞參數分為兩大類

  • 編程式的導航 router.push

  • 聲明式的導航 <router-link>

編程式的導航 router.push

編程式導航傳遞參數有兩種類型:字符串、對象。

字符串

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

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

對象

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

命名路由

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

vue-router中參數傳遞的方式有哪些

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

目標頁面接收傳遞參數時使用params

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

使用方法如下:

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

代碼如下:

<template>
 <div class="hello">
  <h2>{{ msg }}</h2>
  <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>接受傳遞的參數:<template>
 <div>
  this is the news page.the transform param is {{this.$route.params.userId}}
 </div>
</template>
<script>
</script>

運行效果如下:

vue-router中參數傳遞的方式有哪些

查詢參數

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

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

使用方法如下:

this.$router.push({ path: '/news', query: { userId: 123 }});代碼如下:<template>
 <div class="hello">
  <h2>{{ msg }}</h2>
  <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>接收參數如下:<template>
 <div>
  this is the news page.the transform param is {{this.$route.query.userId}}
 </div>
</template>
<script>
</script>

運行效果如下:

vue-router中參數傳遞的方式有哪些

聲明式的導航

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

例子如下:

字符串

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

命名路由

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

運行效果如下:

vue-router中參數傳遞的方式有哪些

查詢參數

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

運行效果如下:

vue-router中參數傳遞的方式有哪些

最后總結:

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

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

2.查詢參數搭配query,刷新頁面數據不會丟失

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

看完上述內容,你們對vue-router中參數傳遞的方式有哪些有進一步的了解嗎?如果還想了解更多知識或者相關內容,請關注億速云行業資訊頻道,感謝大家的支持。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

汤阴县| 盐山县| 锡林郭勒盟| 英超| 阿克陶县| 合肥市| 浮梁县| 枣庄市| 武城县| 呼图壁县| 丰顺县| 绥滨县| 永宁县| 扬州市| 页游| 仁化县| 牙克石市| 县级市| 长丰县| 资源县| 弥渡县| 赤峰市| 鄂州市| 乡城县| 皋兰县| 龙游县| 武陟县| 松潘县| 华容县| 新乡县| 黄山市| 砀山县| 河北省| 阿勒泰市| 庆阳市| 宁陕县| 湘潭县| 瑞昌市| 柏乡县| 什邡市| 漳平市|