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参数”的内容就介绍到这里了,感谢大家的阅读。如果想了解更多行业相关的知识,可以关注恰卡编程网行业资讯频道,小编每天都会为大家更新不同的知识点。
推荐阅读
-
JavaScript闭包用多会造成内存泄露吗
-
javascript中文乱码如何解决
-
Typecho、PHP添加百度是否收录判断提交url优化修改版方法
-
PHP parseurl 一个好用的函数
-
PHP中和URL相关的几个知识点,你都知道吗?
-
PHP发送HTTP请求的6种方法,知道4种算你牛
方法1:用file_get_contents以get方式获取内容:方法2:用fopen打开url,以get方式获...
-
PHP学习第十五天——JavaScript入门DOM对象:二
-
关于sql注入
-
CTF自学笔记(四)服务端请求伪造攻击「一」
-
用PHP判断日期是节假日还是工作日?
最近的一个微信多客服项目需要判断当前的日期是节假日还是工作日,中国的节假日有点复杂,比如端午中秋这些假期是农历,而十一长假又会有补...