JavaScript中如何获取URL参数?4种常见方法详解

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

JavaScript中如何获取URL参数?4种常见方法详解

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

1. 获取方式总结

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

通过正则匹配的方式

立即学习“Java免费学习笔记(深入)”;

利用a标签内置方法

利用split方法分割法

使用URLSearchParams方法

【相关推荐:javascript学习教程】

2. 具体实现方法

2.1 正则匹配法

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

代码如下:

  // 利用正则表达式  let url = "http://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))

登录后复制

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

实现效果:

1.png

2.2 利用a标签

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

2.png

3.png

代码如下:

  let URL = "http://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))

登录后复制

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

实现效果:

4.png

2.3 split分割法

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

代码如下:

  let URL = "http://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))

登录后复制

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

实现效果:

5.png

2.4 URLSearchParams方法

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

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

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

代码如下:

  let URL = "http://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))

登录后复制

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

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

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

实现效果:

6.png

兼容性:

7.png

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

总结

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

【相关视频教程推荐:web前端】

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

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至253000106@qq.com举报,一经查实,本站将立刻删除。

发布者:PHP中文网,转转请注明出处:https://www.chuangxiangniao.com/p/2702203.html

(0)
上一篇 2025年3月7日 19:21:55
下一篇 2025年2月23日 13:04:49

AD推荐 黄金广告位招租... 更多推荐

相关推荐

  • 带你了解JavaScript解构赋值

    本篇文章给大家带来了关于javascript的相关知识,其中主要介绍了关于解构赋值的相关问题,包括了数组解构、对象结构以及解构的用途等等,希望对大家有帮助。 相关推荐:javascript学习教程 概念 ES6提供了更简洁的赋值模式,从数组…

    2025年3月7日
    200
  • javascript数据类型学习之浅析Symbol类型

    本篇文章带大家了解一下es6新增的数据类型:symbol,聊聊symbol类型的声明方式和使用方法,希望对大家有所帮助! Symbol一种新的原始数据类型,表示独一无二的。是javascript中第七种数据类型。另外六种分别是:undefi…

    2025年3月7日
    200
  • 帮你搞定JavaScript对象

    本篇文章给大家带来了关于javascript的相关知识,其中主要介绍了关于对象的相关问题,包括了构造函数和各种内置对象的知识点,希望对大家有帮助。 相关推荐:javascript教程 一、构造函数 为什么使用构造函数 什么是构造函数:是Ja…

    2025年3月7日 编程技术
    200
  • 一文带你深入了解React Hooks!

    react中你了解hooks吗?本篇文章带大家来深入了解下react hooks,希望对大家有所帮助! 前言 Hooks 用于在不编写 class 的情况下,使用 state 以及其他 React 特性。那么 Hooks 究竟是什么,为什么…

    2025年3月7日
    200
  • JavaScript正则表达式,这一篇就够了

    本篇文章给大家带来了关于javascript的相关知识,其中主要介绍了正则表达式的相关问题,正则表达式是一个特定的格式化模式,用于验证各种字符串是否匹配这个特征,进而实现高级的文本查找、替换、截取内容等操作,希望对大家有帮助。 相关推荐:j…

    2025年3月7日 编程技术
    200
  • 为什么会有Symbol类型?怎么使用?

    什么是 symbol?为什么会有这么个东西?下面本篇文章给大家介绍一下javascript中的symbol类型,聊聊使用方法,希望对大家有所帮助! 什么是 Symbol?为什么会有这么个东西? Symbol(符号)是 ES6 新增的数据类型…

    2025年3月7日
    200
  • 一起聊聊JavaScript函数式编程

    本篇文章给大家带来了关于javascript的相关知识,其中主要介绍了函数式编程的相关问题,函数式编程可以理解为,以函数作为主要载体的编程方式,用函数去拆解、抽象一般的表达式,希望对大家有帮助。 相关推荐:javascript学习教程 看过…

    2025年3月7日
    200
  • JavaScript学习理解之JSON(总结分享)

    本篇文章给大家带来了关于javascript的相关知识,其中主要介绍了关于json的相关问题,包括了json对象、json数组和json字符串等等,希望对大家有帮助。 相关推荐:javascript教程 1、JSON对象 任务描述 本关任务…

    2025年3月7日
    200
  • javascript跨域的原因是什么

    JavaScript跨域的原因是:浏览器同源策略限制,当前域名的js只能读取同域下的窗口属性,所以产生跨域。同源策略就是浏览器为了保证用户信息的安全,防止恶意的网站窃取数据,禁止不同域之间的JS进行交互。 本教程操作环境:windows10…

    2025年3月7日
    200
  • 爆肝归纳JavaScript学习知识点

    本篇文章给大家带来了关于javascript的相关知识,其中主要介绍了包括javascript简单入门、javascript基础语法等等整理的知识点,希望对大家有帮助。 相关推荐:javascript教程 一、JavaScript简单入门 …

    2025年3月7日 编程技术
    200

发表回复

登录后才能评论