如何通过JavaScript获取URL参数的四种方法?

2026-04-03 07:551阅读0评论SEO基础
  • 内容介绍
  • 文章标签
  • 相关推荐

本文共计1648个文字,预计阅读时间需要7分钟。

如何通过JavaScript获取URL参数的四种方法?

如何利用原生JavaScript来获取URL链接参数?下面本章节详细介绍4种常见的原生JS方法,希望对大家有所帮助!

作为前端开发者,我们很多时候都需要对URL进行操作和处理。最常见的操作包括:

1. 获取URL参数

2.添加URL参数

3.删除URL参数

4.获取URL的完整路径

以下是对这4种操作的具体介绍和示例代码:

1. 获取URL参数

javascriptfunction getQueryParam(url, key) { const params=new URLSearchParams(new URL(url).search); return params.get(key);}

// 示例const url='https://example.com?name=John&age=30';console.log(getQueryParam(url, 'name')); // 输出:John

2. 添加URL参数javascriptfunction addQueryParam(url, key, value) { const urlObj=new URL(url); const params=new URLSearchParams(urlObj.search); params.append(key, value); urlObj.search=params.toString(); return urlObj.toString();}

// 示例const url='https://example.com';console.log(addQueryParam(url, 'name', 'John')); // 输出:https://example.com?name=John

3. 删除URL参数javascriptfunction deleteQueryParam(url, key) { const urlObj=new URL(url); const params=new URLSearchParams(urlObj.search); params.delete(key); urlObj.search=params.toString(); return urlObj.toString();}

// 示例const url='https://example.com?name=John&age=30';console.log(deleteQueryParam(url, 'age')); // 输出:https://example.com?name=John

4. 获取URL的完整路径javascriptfunction getFullURL(url) { const urlObj=new URL(url); return urlObj.href;}

// 示例const url='https://example.com?name=John&age=30';console.log(getFullURL(url)); // 输出:https://example.com?name=John&age=30

如何利用原生JavaScript来获取URL链接参数?下面本篇文章给大家详细介绍4种常见的原生JS方法,希望对大家有所帮助!

作为一个前端开发,我们很多时候都需要对URL进行操作和处理,最常见的一种就是获取URL链接中携带的参数值了。使用框架开发的小伙伴可能会觉得这很简单,因为框架提供了很多方法让我们方便的获取URL链接携带的参数。但是有些时候我们不能依赖框架,需要我们使用原生JS去获取参数,这也是面试中经常遇到的一道题。今天我们就手撕代码,利用原生JS去获取URL链接参数值。

1. 获取方式总结

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

  • 通过正则匹配的方式

  • 利用a标签内置方法

  • 利用split方法分割法

  • 使用URLSearchParams方法

2. 具体实现方法

2.1 正则匹配法

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

代码如下:

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

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

实现效果:

2.2 利用a标签

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

代码如下:

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

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

实现效果:

2.3 split分割法

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

代码如下:

如何通过JavaScript获取URL参数的四种方法?

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

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

实现效果:

2.4 URLSearchParams方法

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

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

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

代码如下:

<script> let URL = "www.baidu.com?name=elephant&age=25&sex=male&num=100" function queryURLParams(URL) { let url = URL.split("?")[1]; const urlSearchParams = new URLSearchParams(url); const params = Object.fromEntries(urlSearchParams.entries()); return params } console.log(queryURLParams(URL)) </script>

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

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

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

实现效果:

兼容性:

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

总结

这里介绍了四种方法来实现URL链接参数值的解析,其中使用最为广泛的应该当属split分割法。urlSearchParams 作为后起之秀,也逐渐被大家认可,也有很多方法让它兼容IE。

以上就是JavaScript中如何获取URL参数?4种常见方法详解的详细内容,更多请关注自由互联其它相关文章!

本文共计1648个文字,预计阅读时间需要7分钟。

如何通过JavaScript获取URL参数的四种方法?

如何利用原生JavaScript来获取URL链接参数?下面本章节详细介绍4种常见的原生JS方法,希望对大家有所帮助!

作为前端开发者,我们很多时候都需要对URL进行操作和处理。最常见的操作包括:

1. 获取URL参数

2.添加URL参数

3.删除URL参数

4.获取URL的完整路径

以下是对这4种操作的具体介绍和示例代码:

1. 获取URL参数

javascriptfunction getQueryParam(url, key) { const params=new URLSearchParams(new URL(url).search); return params.get(key);}

// 示例const url='https://example.com?name=John&age=30';console.log(getQueryParam(url, 'name')); // 输出:John

2. 添加URL参数javascriptfunction addQueryParam(url, key, value) { const urlObj=new URL(url); const params=new URLSearchParams(urlObj.search); params.append(key, value); urlObj.search=params.toString(); return urlObj.toString();}

// 示例const url='https://example.com';console.log(addQueryParam(url, 'name', 'John')); // 输出:https://example.com?name=John

3. 删除URL参数javascriptfunction deleteQueryParam(url, key) { const urlObj=new URL(url); const params=new URLSearchParams(urlObj.search); params.delete(key); urlObj.search=params.toString(); return urlObj.toString();}

// 示例const url='https://example.com?name=John&age=30';console.log(deleteQueryParam(url, 'age')); // 输出:https://example.com?name=John

4. 获取URL的完整路径javascriptfunction getFullURL(url) { const urlObj=new URL(url); return urlObj.href;}

// 示例const url='https://example.com?name=John&age=30';console.log(getFullURL(url)); // 输出:https://example.com?name=John&age=30

如何利用原生JavaScript来获取URL链接参数?下面本篇文章给大家详细介绍4种常见的原生JS方法,希望对大家有所帮助!

作为一个前端开发,我们很多时候都需要对URL进行操作和处理,最常见的一种就是获取URL链接中携带的参数值了。使用框架开发的小伙伴可能会觉得这很简单,因为框架提供了很多方法让我们方便的获取URL链接携带的参数。但是有些时候我们不能依赖框架,需要我们使用原生JS去获取参数,这也是面试中经常遇到的一道题。今天我们就手撕代码,利用原生JS去获取URL链接参数值。

1. 获取方式总结

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

  • 通过正则匹配的方式

  • 利用a标签内置方法

  • 利用split方法分割法

  • 使用URLSearchParams方法

2. 具体实现方法

2.1 正则匹配法

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

代码如下:

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

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

实现效果:

2.2 利用a标签

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

代码如下:

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

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

实现效果:

2.3 split分割法

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

代码如下:

如何通过JavaScript获取URL参数的四种方法?

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

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

实现效果:

2.4 URLSearchParams方法

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

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

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

代码如下:

<script> let URL = "www.baidu.com?name=elephant&age=25&sex=male&num=100" function queryURLParams(URL) { let url = URL.split("?")[1]; const urlSearchParams = new URLSearchParams(url); const params = Object.fromEntries(urlSearchParams.entries()); return params } console.log(queryURLParams(URL)) </script>

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

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

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

实现效果:

兼容性:

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

总结

这里介绍了四种方法来实现URL链接参数值的解析,其中使用最为广泛的应该当属split分割法。urlSearchParams 作为后起之秀,也逐渐被大家认可,也有很多方法让它兼容IE。

以上就是JavaScript中如何获取URL参数?4种常见方法详解的详细内容,更多请关注自由互联其它相关文章!