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

你可能感兴趣的文章
Mysql: 对换(替换)两条记录的同一个字段值
查看>>
mysql:Can‘t connect to local MySQL server through socket ‘/var/run/mysqld/mysqld.sock‘解决方法
查看>>
MYSQL:基础——3N范式的表结构设计
查看>>
MYSQL:基础——触发器
查看>>
Mysql:连接报错“closing inbound before receiving peer‘s close_notify”
查看>>
mysqlbinlog报错unknown variable ‘default-character-set=utf8mb4‘
查看>>
mysqldump 参数--lock-tables浅析
查看>>
mysqldump 导出中文乱码
查看>>
mysqldump 导出数据库中每张表的前n条
查看>>
mysqldump: Got error: 1044: Access denied for user ‘xx’@’xx’ to database ‘xx’ when using LOCK TABLES
查看>>
Mysqldump参数大全(参数来源于mysql5.5.19源码)
查看>>
mysqldump备份时忽略某些表
查看>>
mysqldump实现数据备份及灾难恢复
查看>>
mysqldump数据库备份无法进行操作只能查询 --single-transaction
查看>>
mysqldump的一些用法
查看>>
mysqli
查看>>
MySQLIntegrityConstraintViolationException异常处理
查看>>
mysqlreport分析工具详解
查看>>
MySQLSyntaxErrorException: Unknown error 1146和SQLSyntaxErrorException: Unknown error 1146
查看>>
Mysql_Postgresql中_geometry数据操作_st_astext_GeomFromEWKT函数_在java中转换geometry的16进制数据---PostgreSQL工作笔记007
查看>>