当前位置: 代码网 > it编程>编程语言>Javascript > JS获取地址栏参数的两种方法(原生、vue)

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

2024年09月07日 Javascript 我要评论
若地址栏url为:code-nav/article/917?type=12&title=abc,我们要获取到地址栏后面的的type和title参数,如何才能拿到呢?解决方案:1.原生js实现:

若地址栏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.type
  console.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.id
  console.log('id', id) // 917
})
 
</script>

到此这篇关于js获取地址栏参数的两种方法(原生、vue)的文章就介绍到这了,更多相关js获取地址栏参数内容请搜索代码网以前的文章或继续浏览下面的相关文章希望大家以后多多支持代码网!

(0)

相关文章:

版权声明:本文内容由互联网用户贡献,该文观点仅代表作者本人。本站仅提供信息存储服务,不拥有所有权,不承担相关法律责任。 如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 2386932994@qq.com 举报,一经查实将立刻删除。

发表评论

验证码:
Copyright © 2017-2025  代码网 保留所有权利. 粤ICP备2024248653号
站长QQ:2386932994 | 联系邮箱:2386932994@qq.com