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

你可能感兴趣的文章
Objective-C实现图片erosion operation侵蚀操作算法(附完整源码)
查看>>
Objective-C实现图片的放大缩小(附完整源码)
查看>>
Objective-C实现图片腐蚀(附完整源码)
查看>>
Objective-C实现图片膨胀(附完整源码)
查看>>
Objective-C实现图的邻接矩阵(附完整源码)
查看>>
Objective-C实现圆球的表面积和体积(附完整源码)
查看>>
Objective-C实现在Regex的帮助下检查字谜算法(附完整源码)
查看>>
Objective-C实现在指定区间 [a, b] 中找到函数的实根,其中 f(a)*f(b) < 0算法(附完整源码)
查看>>
Objective-C实现均值滤波(附完整源码)
查看>>
Objective-C实现埃拉托斯特尼筛法算法(附完整源码)
查看>>
Objective-C实现域名解析(附完整源码)
查看>>
Objective-C实现域名转IP(附完整源码)
查看>>
Objective-C实现培根密码算法(附完整源码)
查看>>
Objective-C实现基于 LIFO的堆栈算法(附完整源码)
查看>>
Objective-C实现基于 LinkedList 的添加两个数字的解决方案算法(附完整源码)
查看>>
Objective-C实现基于opencv的抖动算法(附完整源码)
查看>>
Objective-C实现基于事件对象实现线程同步(附完整源码)
查看>>
Objective-C实现基于信号实现线程同步(附完整源码)
查看>>
Objective-C实现基于文件流拷贝文件(附完整源码)
查看>>
Objective-C实现基于模板的双向链表(附完整源码)
查看>>