JavaScript中怎么获取URL参数

JavaScript中怎么获取URL参数

这篇文章主要介绍“JavaScript中怎么获取URL参数”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“JavaScript中怎么获取URL参数”文章能帮助大家解决问题。

1. 获取方式总结

利用原生JS获取URL链接参数的方法也有好几种,今天我们依次来讲解常见的几种:

  • 通过正则匹配的方式

  • 利用a标签内置方法

  • 利用split方法分割法

  • 使用URLSearchParams方法

2. 具体实现方法

2.1 正则匹配法

这是非常中规中举的一种方法,重点是要求我们要懂正则表达式。

代码如下:

<script>//利用正则表达式leturl="http://www.baidu.com?name=elephant&age=25&sex=male&num=100"////返回参数对象functionqueryURLParams(url){letpattern=/(\w+)=(\w+)/ig;//定义正则表达式letparames={};//定义参数对象url.replace(pattern,($,$1,$2)=>{parames[$1]=$2;});returnparames;}console.log(queryURLParams(url))</script>

上段代码中重点是正则表达式的定义以及replace方法的使用,其中1、$2分别代表name=elephant、name、elephant,以此类推。replace结合正则更加详细的使用方法可以自行下去学习。

实现效果:

2.2 利用a标签

这种方法较少人使用,因为毕竟有点黑科技的意思在里面。它的原理主要就是利用了a标签得到一些内置属性,如href、hash、search等属性。

代码如下:

<script>letURL="http://www.baidu.com?name=elephant&age=25&sex=male&num=100#smallpig"functionqueryURLParams(url){//1.创建a标签letlink=document.createElement('a');link.href=url;letsearchUrl=link.search.substr(1);//获取问号后面字符串lethashUrl=link.hash.substr(1);//获取#后面的值letobj={};//声明参数对象//2.向对象中进行存储hashUrl?obj['HASH']=hashUrl:null;//#后面是否有值letlist=searchUrl.split("&");for(leti=0;i<list.length;i++){letarr=list[i].split("=");obj[arr[0]]=arr[1];}returnobj;}console.log(queryURLParams(URL))</script>

上段代码中先创建了一个a标签,然后就可以根据a标签的属性分别得到url的各个部分了,这其实和Vue的路由跳转获取参数有点类似。

实现效果:

2.3 split分割法

该种方法利用了split可以以某个字符讲字符串分割为数组的特点,巧妙地将各个参数分割出来。

代码如下:

<script>letURL="http://www.baidu.com?name=elephant&age=25&sex=male&num=100"functionqueryURLParams(URL){//consturl=location.search;//项目中可直接通过search方法获取url中"?"符后的字串leturl=URL.split("?")[1];letobj={};//声明参数对象letarr=url.split("&");//以&符号分割为数组for(leti=0;i<arr.length;i++){letarrNew=arr[i].split("=");//以"="分割为数组obj[arrNew[0]]=arrNew[1];}returnobj;}console.log(queryURLParams(URL))</script>

上传代码中如果在实际项目中,可以直接利用location.search获取“?”后面的字符串,这里为了方便演示,所以利用split分割了以下。

实现效果:

2.4 URLSearchParams方法

URLSearchParams方法能够让我们非常方便的获取URL参数,但是存在一定的兼容性问题,官网的解释如下:

URLSearchParams 接口定义了一些实用的方法来处理 URL 的查询字符串。

该接口提供了非常的的方法让我们来处理URL参数,这里我们只介绍如何获取URL参数值,更加详细的使用方法大家可以参考官网。

代码如下:

<script>letURL="http://www.baidu.com?name=elephant&age=25&sex=male&num=100"functionqueryURLParams(URL){leturl=URL.split("?")[1];consturlSearchParams=newURLSearchParams(url);constparams=Object.fromEntries(urlSearchParams.entries());returnparams}console.log(queryURLParams(URL))</script>

这里我们基本上只用了两行主要代码就实现了参数的解析。需要注意的是urlSearchParams.entries()返回的是一个迭代协议iterator,所以我们需要利用Object.fromEntries()方法将把键值对列表转换为一个对象。

关于迭代协议,大家可以参考官网:

https://developer.mozilla.org/zh-CN/docs/Web/JavaScript/Reference/Iteration_protocols

实现效果:

兼容性:

可以看到我们这个接口不兼容万恶之源的IE。

关于“JavaScript中怎么获取URL参数”的内容就介绍到这里了,感谢大家的阅读。如果想了解更多行业相关的知识,可以关注恰卡编程网行业资讯频道,小编每天都会为大家更新不同的知识点。

发布于 2022-03-17 21:19:28
收藏
分享
海报
0 条评论
37
上一篇:vue中v-if怎么用 下一篇:python如何将两个列表转化为字典
目录

    0 条评论

    本站已关闭游客评论,请登录或者注册后再评论吧~

    忘记密码?

    图形验证码