日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 前端技术 > vue >内容正文

vue

vue获取浏览器地址栏参数(?及/)路由+非路由实现方式

發布時間:2023/12/10 vue 36 豆豆
生活随笔 收集整理的這篇文章主要介紹了 vue获取浏览器地址栏参数(?及/)路由+非路由实现方式 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

1、? 參數

瀏覽器參數形式:http://javam4.com/m4detail?id=1322914793170014208

1.1、路由取參方式
this.$route.query.id

前端跳轉方式:

一、onclick方式 <a title="測試數據"@click="test(row.id)"target="_blank"><span>{{ row.title }}</span> </a>test(id) {this.$router.push({path: "/m4detail",query: {id: id}}); }二、a標簽直接跳轉 <a title="測試數據":href="javam4.com/m4detail/' + row.id"target="_blank"><span>{{ row.title }}</span> </a>

簡單粗暴,只要你的瀏覽器地址欄參數帶 ?號,不管你是咋跳轉過來的, this.$route.query 后面直接 . 對應的參數就可以取到值,比如 ?id=1323968&name=1111

對應效果如下:

1.2、js取參方式

在 mothod 方法添加如下方法:

getUrlKey: function (name) {return decodeURIComponent((new RegExp('[?|&]' + name + '=' + '([^&;]+?)(&|#|;|$)').exec(location.href) || [, ""])[1].replace(/\+/g, '%20')) || null }

調用直接通過 getUrlKey(參數名稱),具體如下:

2、/ 參數

瀏覽器參數形式:http://javam4.com/m4detail/1322914793170014208

2.1、路由方式

路由參數配置如下:

{ path: 'm4detail/:id', title: 'java面試網', name: 'm4detail', component: () => import('@/views/javam4/m4detail.vue') },

也就是由以前的 path: 'm4detail' > path: 'm4detail/:id'

這種方式需要 <router-link> 標簽配合使用:

<router-link :to="路徑"></router-link>

而界面跳轉的時候因為通常是一個 <a> 標簽,所以就可以不用了,直接套一層:

<router-link :to="`/m4detail/`+row.id" target="_blank"><a><span>{{row.title}}</span></a> </router-link>

參數說明:

  • to:跳轉路徑,對應路由的 path
  • target:跳轉方式,跟a標簽用法一樣

界面取參:

this.$route.params.id

效果如下:

2.2、非路由方式

在 mothod 方法添加如下方法:

getUrlKey: function (directory) {return decodeURIComponent((new RegExp('/' + directory + '.*/([^/]+)/?$').exec(location.href) || [, ""])[1].replace(/\+/g, '%20')) || null }

其中 directory 表示那個目錄后面的參數,比如:javam4.com/m4detail/11111111111

那么在這取值就是 m4detail,其實使用這種方式,無非還是用正則表達式切割一下,如果覺得正則不滿足大家也可以自行修改。

let id = this.getUrlKey("m4detail"); console.log("this.id:"+id);

代碼截圖:

效果截圖:

希望這篇文章對你有所幫助。

博客園:https://www.cnblogs.com/niceyoo

總結

以上是生活随笔為你收集整理的vue获取浏览器地址栏参数(?及/)路由+非路由实现方式的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。