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

 更新时间:2024年07月19日 08:47:08   作者:-草莓星球杯  
这篇文章主要介绍了JS获取地址栏参数的两种方法(原生、vue),文中通过代码示例讲解的非常详细,对大家的学习或工作有一定的帮助,需要的朋友可以参考下

若地址栏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获取地址栏参数内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • javascript静态的url如何传递

    javascript静态的url如何传递

    javascript静态的url如何传递...
    2007-05-05
  • JavaScript 防篡改对象的用法示例

    JavaScript 防篡改对象的用法示例

    这篇文章主要介绍了JavaScript 防篡改对象的用法示例,帮助大家更好的理解和学习使用JavaScript,感兴趣的朋友可以参考下
    2021-04-04
  • JS基于对象的特性实现去除数组中重复项功能详解

    JS基于对象的特性实现去除数组中重复项功能详解

    这篇文章主要介绍了JS基于对象的特性实现去除数组中重复项功能,结合实例形式较为详细的分析了js基于key值唯一性实现数组去重的具体步骤与相关操作技巧,需要的朋友可以参考下
    2017-11-11
  • 超轻量级的js时间库miment使用解析

    超轻量级的js时间库miment使用解析

    这篇文章主要介绍了超轻量级的js时间库miment使用解析,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
    2019-08-08
  • SVG快速构建马赛克效果

    SVG快速构建马赛克效果

    这篇文章主要为大家介绍了SVG快速构建马赛克效果示例,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2022-06-06
  • jquery在Chrome下获取图片的长宽问题解决

    jquery在Chrome下获取图片的长宽问题解决

    需要获得图片的长宽,在IE、FireFox下均正常,就TMD在Chrome中不行,有人说是Chrome版本的问题,最终终于找到了解决方法,在这与大家分享下
    2013-03-03
  • javascript实现页面刷新时自动清空表单并选中的方法

    javascript实现页面刷新时自动清空表单并选中的方法

    这篇文章主要介绍了javascript实现页面刷新时自动清空表单并选中的方法,涉及javascript中reset与focus方法的相关使用技巧,具有一定参考借鉴价值,需要的朋友可以参考下
    2015-07-07
  • javascript实现在指定元素中垂直水平居中

    javascript实现在指定元素中垂直水平居中

    当谈到网页的布局中,居中问题一直得不到很有效的解决,居中通常是相对于某一个元素的,比如我们经常所说的屏幕居中的问题,我们了解父元素的信息越多,我们就越能更加容易的实现居中布局。下面我们通过具体的实例来看看javascript如何来实现垂直水平居中
    2015-09-09
  • 微信小程序模板template简单用法示例

    微信小程序模板template简单用法示例

    这篇文章主要介绍了微信小程序模板template简单用法,结合实例形式分析了微信小程序模板template的功能、简单使用方法及相关操作注意事项,需要的朋友可以参考下
    2018-12-12
  • javascript实现登录框拖拽

    javascript实现登录框拖拽

    这篇文章主要为大家详细介绍了javascript实现登录框拖拽,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2022-08-08

最新评论