博客
关于我
获取url 中的参数
阅读量:779 次
发布时间:2019-03-24

本文共 1046 字,大约阅读时间需要 3 分钟。

方法一:使用正则表达式

要提取 URL 中的查询参数,可以使用正则表达式来匹配特定参数值。以下函数可以实现此功能:

function getQueryString(name) {    var reg = new RegExp("(^|&)" + name + "=([^&]*)(&|$)", "i");    var r = window.location.search.substr(1).match(reg);    if (r != null) {        return unescape(decodeURI(r[2]));    }    return null;}

这个函数通过创建包含目标参数的正则表达式来匹配 URL 中的查询部分。函数首先移除 URL 中的 ?,然后使用正则表达式来寻找指定参数的值。如果找到匹配项,函数会对参数值进行 URL 解码并去除 HTML 实体编码,返回结果。

这种方法在大多数现代浏览器中都能有效工作,并且代码简洁易懂。


方法二:使用 URLSearchParams(IE 浏览器不兼容)

如果你需要更简洁的代码,可以使用 URLSearchParams 类,这个方法主要用于解析 URL 查询字符串。以下函数可以实现此功能:

function getUrlParam(name) {    var temp = window.location.href.split('?')[1];    var pram = new URLSearchParams('?'+temp);    return pram.get(name);}

这个函数首先提取 URL 中的查询部分,并将其传递给 URLSearchParams 构造函数。然后通过 get 方法来获取指定参数的值。如果参数不存在,函数会返回 null

这种方法在现代浏览器中运行非常流畅,但由于 IE 浏览器不支持这个 API,因此在需要兼容 IE 的项目中需要谨慎使用。


综合比较

  • 方法一:简单易用,支持所有浏览器,但代码稍微复杂一些。
  • 方法二:代码简洁,但在需要支持 IE 的项目中可能会存在兼容性问题。

在大多数现代项目中,两种方法都可以有效地使用。但如果需要支持 IE 浏览器,建议优先选择 方法一,因为 URLSearchParams 在 IE 中不支持。


总结

这两种方法都是提取 URL 查询参数的有效方式。选择哪种方法取决于你对浏览器兼容性的要求以及你对代码的偏好。

转载地址:http://hqmkk.baihongyu.com/

你可能感兴趣的文章
multipart/form-data与application/octet-stream的区别、application/x-www-form-urlencoded
查看>>
mysql cmake 报错,MySQL云服务器应用及cmake报错解决办法
查看>>
Multiple websites on single instance of IIS
查看>>
mysql CONCAT()函数拼接有NULL
查看>>
multiprocessing.Manager 嵌套共享对象不适用于队列
查看>>
multiprocessing.pool.map 和带有两个参数的函数
查看>>
MYSQL CONCAT函数
查看>>
multiprocessing.Pool:map_async 和 imap 有什么区别?
查看>>
MySQL Connector/Net 句柄泄露
查看>>
multiprocessor(中)
查看>>
mysql CPU使用率过高的一次处理经历
查看>>
Multisim中555定时器使用技巧
查看>>
MySQL CRUD 数据表基础操作实战
查看>>
multisim变压器反馈式_穿过隔离栅供电:认识隔离式直流/ 直流偏置电源
查看>>
mysql csv import meets charset
查看>>
multivariate_normal TypeError: ufunc ‘add‘ output (typecode ‘O‘) could not be coerced to provided……
查看>>
MySQL DBA 数据库优化策略
查看>>
multi_index_container
查看>>
MySQL DBA 进阶知识详解
查看>>
Mura CMS processAsyncObject SQL注入漏洞复现(CVE-2024-32640)
查看>>