博客
关于我
获取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/

你可能感兴趣的文章
mysqlreport分析工具详解
查看>>
MySQLSyntaxErrorException: Unknown error 1146和SQLSyntaxErrorException: Unknown error 1146
查看>>
Mysql_Postgresql中_geometry数据操作_st_astext_GeomFromEWKT函数_在java中转换geometry的16进制数据---PostgreSQL工作笔记007
查看>>
mysql_real_connect 参数注意
查看>>
mysql_secure_installation初始化数据库报Access denied
查看>>
MySQL_西安11月销售昨日未上架的产品_20161212
查看>>
Mysql——深入浅出InnoDB底层原理
查看>>
MySQL“被动”性能优化汇总
查看>>
MySQL、HBase 和 Elasticsearch:特点与区别详解
查看>>
MySQL、Redis高频面试题汇总
查看>>
MYSQL、SQL Server、Oracle数据库排序空值null问题及其解决办法
查看>>
mysql一个字段为空时使用另一个字段排序
查看>>
MySQL一个表A中多个字段关联了表B的ID,如何关联查询?
查看>>
MYSQL一直显示正在启动
查看>>
MySQL一站到底!华为首发MySQL进阶宝典,基础+优化+源码+架构+实战五飞
查看>>
MySQL万字总结!超详细!
查看>>
Mysql下载以及安装(新手入门,超详细)
查看>>
MySQL不会性能调优?看看这份清华架构师编写的MySQL性能优化手册吧
查看>>
MySQL不同字符集及排序规则详解:业务场景下的最佳选
查看>>
Mysql不同官方版本对比
查看>>