当前位置: 首页> 文旅> 美景 > JS获取地址栏参数的方法(原生、vue)

JS获取地址栏参数的方法(原生、vue)

时间:2025/7/13 6:17:54来源:https://blog.csdn.net/qq_33225414/article/details/140514985 浏览次数:0次

若地址栏URL为:code-nav/article/917?type=12&title=abc,我们要获取到地址栏后面的的type和title参数,如何才能拿到呢?

解决方案:

1.原生JS实现:

1.1 采用正则表达式获取地址栏参数(第一种方法)
//获取地址栏参数,key:参数名称
function getUrlParams(key) {let reg = new RegExp("(^|&)" + key + "=([^&]*)(&|$)");let r = window.location.search.substr(1).match(reg);if (r != null)return unescape(r[2]);return null;
}
let title = getUrlParams("title"); // abc
let type = getUrlParams("type"); // 12
1.2 传统方法截取实现(第二种方法)
//获取地址栏参数
function getUrlParams() {let url = window.location.search; //获取url中"?"符后的字串let paramsObj = new Object();if (url.indexOf("?") != -1) {let str = url.substr(1);str = str.split("&");for (let i = 0; i < str.length; i++) {paramsObj[str[i].split("=")[0]] = decodeURI(str[i].split("=")[1]);}}return paramsObj;
}
let type = getUrlParams().type; // 12
let title = getUrlParams().title; // abc

2.Vue框架实现:

2.1 查询参数获取(场景一)

我们需要从地址code-nav/article/917?type=12&title=abc上拿到title的value abc。

<script setup>
import {useRouter} from 'vue-router'const { currentRoute } = useRouter();
const route = currentRoute.value;onMounted(()=>{let type=route.query.typeconsole.log('type', type) // 12
})
</script>
2.2 获取路径参数(场景二)

我们需要从地址code-nav/article/917上拿到917这个参数。

首先需要在router/index.js中定义好路由以及路径参数,如下代码:

import { createRouter, createWebHistory } from 'vue-router'const router = createRouter({history: createWebHistory(import.meta.env.BASE_URL),routes: [{path: '/:id',name: 'home',component: () => import('../views/home.vue')},]
})export default router

接着就可以在home.vue组件中通过路由useRouter得到参数,注意是route.params,如下代码:

<script setup>
import {useRouter} from 'vue-router'const { currentRoute } = useRouter();
const route = currentRoute.value;onMounted(()=>{let id=route.params.idconsole.log('id', id) // 917
})</script>

关键字:JS获取地址栏参数的方法(原生、vue)

版权声明:

本网仅为发布的内容提供存储空间,不对发表、转载的内容提供任何形式的保证。凡本网注明“来源:XXX网络”的作品,均转载自其它媒体,著作权归作者所有,商业转载请联系作者获得授权,非商业转载请注明出处。

我们尊重并感谢每一位作者,均已注明文章来源和作者。如因作品内容、版权或其它问题,请及时与我们联系,联系邮箱:809451989@qq.com,投稿邮箱:809451989@qq.com

责任编辑: