一区二区三区在线-一区二区三区亚洲视频-一区二区三区亚洲-一区二区三区午夜-一区二区三区四区在线视频-一区二区三区四区在线免费观看

服務器之家:專注于服務器技術及軟件下載分享
分類導航

node.js|vue.js|jquery|angularjs|React|json|js教程|

服務器之家 - 編程語言 - JavaScript - Vue router傳遞參數并解決刷新頁面參數丟失問題

Vue router傳遞參數并解決刷新頁面參數丟失問題

2021-12-01 16:33月半圓兒丨TED JavaScript

這篇文章主要介紹了Vue router傳遞參數并解決刷新頁面參數丟失問題,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧

Vue Router 傳參方式:

1. this.$router.push({ name: '模塊名稱', params: { // 各參數 } })

router.js:

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
export default new Router({
 routes: [
  {
   path: '/paramsPassingByRouter',
   component: ParamsPassingByRouter,
   children: [
    {
     path: 'paramsMode',
     name: 'paramsMode',
     component: ParamsMode
    }
   ]
  }
 ]
})

ParamsPassingByRouter.vue:

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
<!-- html -->
<button @click="paramsMode(testData)">params傳參</button>
 
<!-- js -->
<script>
export default {
 data () {
  return {
   testData: {
    id: '20180101',
    name: '張三',
    aka: 'z3',
    age: '18'
   }
  }
 },
 methods: {
  paramsMode (data) {
   this.$router.push({
    name: 'paramsMode',
    params: data
   })
  }
 }
}
</script>

ParamsMode.vue:

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
<!-- html -->
<div class="params-mode">{{ testData }}</div>
 
<!-- js -->
<script>
export default {
 data () {
  return {
   testData: {}
  }
 },
 created () {
  this.testData = this.$route.params
 }
}
</script>

效果:
url:http://localhost:8081/#/paramsPassingByRouter/paramsMode
頁面顯示:{"id":"20180101","name":"張三","aka":"z3","age":"18"}

但是刷新頁面后,數據會丟失,顯示:{}。

2. this.$router.push({ name: '模塊名稱', query: { // 各參數 } })

router.js:

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
export default new Router({
 routes: [
  {
   path: '/paramsPassingByRouter',
   component: ParamsPassingByRouter,
   children: [
    {
     path: 'queryMode',
     name: 'queryMode',
     component: QueryMode
    }
   ]
  }
 ]
})

ParamsPassingByRouter.vue:

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
<!-- html -->
<button @click="queryMode(testData)">query傳參</button>
 
<!-- js -->
<script>
export default {
 data () {
  return {
   testData: {
    id: '20180101',
    name: '張三',
    aka: 'z3',
    age: '18'
   }
  }
 },
 methods: {
  queryMode (data) {
   this.$router.push({
    name: 'paramsMode',
    query: data
   })
  }
 }
}
</script>

QueryMode.vue:

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
<!-- html -->
<div class="query-mode">{{ testData }}</div>
 
<!-- js -->
<script>
export default {
 data () {
  return {
   testData: {}
  }
 },
 created () {
  this.testData = this.$route.query
 }
}
</script>

效果:
url:http://localhost:8081/#/paramsPassingByRouter/queryMode?id=20180101&name=%E5%BC%A0%E4%B8%89&aka=z3&age=18
頁面顯示:{"id":"20180101","name":"張三","aka":"z3","age":"18"}

刷新頁面后,數據不會丟失。

解決刷新頁面數據丟失的方案:

使用 this.$router.push({ name: '模塊名稱', query: { // 各參數 } }) 方式傳參。

缺點:參數值都拼接在 url 上,url 會很長,同時都可被看到。

this.$router.push({ name: '模塊名稱', params: { // 各參數 } }) 路由文件設置的時候把參數拼到 url 里。

url:http://localhost:8081/#/paramsPassingByRouter/paramsMode/20180101/%E5%BC%A0%E4%B8%89/z3/18
缺點:同上。

1 和 2 結合使用:this.$router.push({ name: '模塊名稱', params: { // 各參數 }, query: { // 各參數 } })。

老老實實的用 localStorage 存儲。

url: http://localhost:8081/#/paramsPassingByRouter/paramsMode/z3
可以與 params 和 query 方式配合使用,可以暴露的參數顯示在 url 上,同時刷新參數也不會丟失。
銷毀頁面的時候把 localStorage 存儲的內容清除。

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
// router.js
{
 path: 'paramsMode/:aka',
 name: 'paramsMode',
 component: ParamsMode
}
 
<!-- ParamsMode.vue 修改 -->
<script>
export default {
 data () {
  return {
   testData: {}
  }
 },
 created () {
  const tempData = localStorage.getItem('tempData')
  if (tempData) {
   this.testData = JSON.parse(tempData)
  } else {
   this.testData = this.$route.params
 
   localStorage.setItem('tempData', JSON.stringify(this.$route.params))
  }
 },
 beforeDestroy () {
  localStorage.removeItem('tempData')
 }
}
</script>

到此這篇關于Vue router傳遞參數并解決刷新頁面參數丟失問題的文章就介紹到這了,更多相關Vue router傳遞參數丟失內容請搜索服務器之家以前的文章或繼續瀏覽下面的相關文章希望大家以后多多支持服務器之家!

原文鏈接:https://segmentfault.com/a/1190000019699706

延伸 · 閱讀

精彩推薦
主站蜘蛛池模板: 国产成人亚洲精品91专区手机 | 日本一道一区二区免费看 | 日韩一品在线播放视频一品免费 | 日本加勒比在线播放 | 农村妇女野外牲交一级毛片 | 亚洲免费一 | 亚洲+国产+图片 | 1769国产精品免费视频 | 8x8拨擦拨擦华人免费 | 免费看成人毛片日本久久 | 亚洲天堂视频在线播放 | 顶级欧美做受xxx000大乳 | 唯美清纯 自拍偷 | 国产成人99久久亚洲综合精品 | 青青草在线观看 | 亚洲国产一区二区三区青草影视 | 爽爽影院免费观看 | 短篇最污的乱淫伦小说全集 | 国产精品自产拍在线观看2019 | 男人与雌性宠物交啪啪小说 | 无码毛片内射白浆视频 | 无人区尖叫之夜美女姐姐视频 | 亚洲天堂影院在线观看 | 色老妈| 全色黄大色黄大片爽一次 | sxx免费看观看美女 sss亚洲国产欧美一区二区 | 免费看1级伦理 | 欧美艳星kagneyiynn | 亚洲欧美日韩久久一区 | 亚洲无人区乱码中文字幕 | 亚洲国产成人久久77 | 亚洲香蕉伊在人在线观看9 亚洲系列国产系列 | 激情文学综合网 | 免费片在线观看高清 | 久久不射视频 | 欧美一区二区三区大片 | 隔壁老王国产在线精品 | 好 舒服 好 粗 好硬免费视频 | 翁息肉小说老扒 | 国产特黄a级在线视频 | 免费三及片 |