首先,获取URL中的参数是Web开发经常需要的功能。JavaScript提供了多种方式可以获取URL参数,本文将介绍其中两种最常见的方式:URLSearchParams和正则表达式。
首先,获取URL中的参数是Web开发经常需要的功能。JavaScript提供了多种方式可以获取URL参数,本文将介绍其中两种最常见的方式:URLSearchParams和正则表达式。
使用URLSearchParams
URLSearchParams是一个原生对象,主要用来操作URL查询参数。使用URLSearchParams获取URL参数非常方便。
我们可以用如下代码创建一个URLSearchParams对象:
const urlParams = new URLSearchParams(window.location.search);
这个新建的URLSearchParams对象会自动从当前网页的URL中获取查询参数。如果你想获取另外一个链接中的参数,只需把该链接作为参数传递给URLSearchParams构造函数即可。
一旦我们有了urlParams对象,我们就可以通过调用get()、getAll()、has()、set()、delete()、keys()、values()和entries()方法对其进行查询和修改。下面是几个例子。
获取指定参数的值
const myParam = urlParams.get('myParam');
console.log(myParam);
检查是否存在参数
if (urlParams.has('myParam')) {
// do something
}
使用正则表达式
虽然URLSearchParams是一种非常方便的获取URL参数的方法,但有些时候我们还是需要使用正则表达式来取得它们。
下面是一些正则表达式的示例。
获取所有参数
const url = window.location.href;
const pattern = /[?&](\w+)=([^&#]*)/g;
let params = {};
let match;
while (match = pattern.exec(url)) {
params[match[1]] = decodeURIComponent(match[2]);
}
console.log(params);
获取指定参数的值
function getParameterByName(name, url = window.location.href) {
name = name.replace(/[\[\]]/g, '\\$&');
const regex = new RegExp('[?&]' + name + '(=([^&#]*)|&|#|$)');
const results = regex.exec(url);
if (!results) {
return null;
}
if (!results[2]) {
return '';
}
return decodeURIComponent(results[2].replace(/\+/g, ' '));
}
console.log(getParameterByName('myParam'));
以上就是使用URLSearchParams和正则表达式获取URL参数的MarkDown文档攻略,希望对您有所帮助。
本文标题为:浅析JS获取url中的参数实例代码
基础教程推荐
- SpringBoot使用thymeleaf实现一个前端表格方法详解 2023-06-06
- 深入了解Java包与访问控制权限 2023-05-25
- Java如何提供给第三方使用接口方法详解 2022-09-03
- Java协议字节操作工具类详情 2023-05-14
- 可能是全网最详细的springboot整合minio教程 2023-01-02
- log4j2使用filter过滤日志方式 2023-08-08
- MyBatisPlus超详细分析条件查询 2023-04-18
- javaWeb实现简单文件上传 2023-01-24
- java – 使用Room persistence库和sqlite 2023-11-04
- java – 如何在MySQL中的INT列中区分0和null 2023-11-08