我的编程空间,编程开发者的网络收藏夹
学习永远不晚

如何使用原生JS获取URL链接参数

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

如何使用原生JS获取URL链接参数

这篇文章将为大家详细讲解有关如何使用原生JS获取URL链接参数,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。

1. 获取方式总结

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

  • 通过正则匹配的方式

  • 利用a标签内置方法

  • 利用split方法分割法

  • 使用URLSearchParams方法

2. 具体实现方法

2.1 正则匹配法

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

代码如下:

<script>  // 利用正则表达式  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))</script>

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

实现效果:

如何使用原生JS获取URL链接参数

2.2 利用a标签

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

如何使用原生JS获取URL链接参数

如何使用原生JS获取URL链接参数

代码如下:

<script>  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))</script>

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

实现效果:

如何使用原生JS获取URL链接参数

2.3 split分割法

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

代码如下:

<script>  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))</script>

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

实现效果:

如何使用原生JS获取URL链接参数

2.4 URLSearchParams方法

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

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

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

代码如下:

<script>  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))</script>

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

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

实现效果:

如何使用原生JS获取URL链接参数

兼容性:

如何使用原生JS获取URL链接参数

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

附:获取URL携带参数实例

getUrlParamValue = function (name) {if (name == null || name == 'undefined') {return null; }var searchStr = decodeURI(location.search);var infoIndex = searchStr.indexOf(name + "=");if (infoIndex == -1) { return null; }var searchInfo = searchStr.substring(infoIndex + name.length + 1);var tagIndex = searchInfo.indexOf("&");if (tagIndex!= -1) { searchInfo = searchInfo.substring(0, tagIndex); }return searchInfo;};

关于“如何使用原生JS获取URL链接参数”这篇文章就分享到这里了,希望以上内容可以对大家有一定的帮助,使各位可以学到更多知识,如果觉得文章不错,请把它分享出去让更多的人看到。

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

如何使用原生JS获取URL链接参数

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

如何使用原生JS获取URL链接参数

这篇文章将为大家详细讲解有关如何使用原生JS获取URL链接参数,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。1. 获取方式总结利用原生JS获取URL链接参数的方法也有好几种,今天我们依次来讲解常见的几种:
2023-06-29

js如何获取URL中的参数

这篇文章主要介绍js如何获取URL中的参数,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!获取 URL 中的参数这个需求在三大框架的时代应用貌似不多了,不过面试中问的还是蛮多的,了解一下是好的简单实现var urlPa
2023-06-27

JS如何获取URL中的Query参数

这篇文章主要介绍了JS如何获取URL中的Query参数问题,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
2023-01-17

使用js获取url中的参数并返回一个对象方式

这篇文章主要介绍了使用js获取url中的参数并返回一个对象方式,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
2023-01-17

如何在Jersey中使用Restful接口获取参数

如何在Jersey中使用Restful接口获取参数?相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。1.@PathParam使用该注释获取参数时可以获取URI中制定规则的参数例如:
2023-06-15

如何使用原生JS获取select元素选中的value和text值

本篇内容主要讲解“如何使用原生JS获取select元素选中的value和text值”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“如何使用原生JS获取select元素选中的value和text值”
2023-06-29

微信小程序直播如何获取分享卡片链接参数

这篇文章主要介绍“微信小程序直播如何获取分享卡片链接参数”,在日常操作中,相信很多人在微信小程序直播如何获取分享卡片链接参数问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”微信小程序直播如何获取分享卡片链接参数
2023-06-26

如何在python中使用sys模块获取参数

本篇文章给大家分享的是有关如何在python中使用sys模块获取参数,小编觉得挺实用的,因此分享给大家学习,希望大家阅读完这篇文章后可以有所收获,话不多说,跟着小编一起来看看吧。1、 sys.argv获取脚本传递的所有参数,返回一个列表。列
2023-06-15

阿里云服务器分享链接如何获取和使用

阿里云服务器分享链接是阿里云提供的一种便捷的方式,让用户可以快速获取和使用云服务器资源。本文将介绍如何获取和使用阿里云服务器分享链接,并通过实例展示其优势和应用场景。详细说明:1.获取阿里云服务器分享链接首先,登录阿里云官网并进入控制台页面。在控制台页面中,选择“产品与服务”中的“云服务器ECS”选项。然后,在左
阿里云服务器分享链接如何获取和使用
2024-01-16

如何使用java过滤器获取所有参数值

要使用Java过滤器获取所有参数值,可以按照以下步骤进行操作:1. 创建一个类实现`javax.servlet.Filter`接口,并重写`doFilter`方法。```javapublic class MyFilter implement
2023-09-06

如何使用 PHP 反射在函数中获取参数信息?

php 反射可通过 reflectionfunction 类和 reflectionparameter 对象获取函数参数信息,包括:getname(): 参数名称gettype(): 参数类型isoptional(): 可选性ispasse
如何使用 PHP 反射在函数中获取参数信息?
2024-04-11

使用controller接收js传过来的参数问题如何解决

本文小编为大家详细介绍“使用controller接收js传过来的参数问题如何解决”,内容详细,步骤清晰,细节处理妥当,希望这篇“使用controller接收js传过来的参数问题如何解决”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一
2023-07-05

如何使用gin框架获取Golang http post请求的原始数据

php小编小新为您介绍如何使用gin框架获取Golang http post请求的原始数据。在Golang中,使用gin框架可以便捷地处理http请求,包括post请求。通过gin框架提供的Context对象,可以轻松获取post请求中的原
如何使用gin框架获取Golang http post请求的原始数据
2024-02-22

vue中如何使用echarts实现动态数据绑定及获取后端接口数据

本篇内容主要讲解“vue中如何使用echarts实现动态数据绑定及获取后端接口数据”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“vue中如何使用echarts实现动态数据绑定及获取后端接口数据”
2023-07-02

编程热搜

  • Python 学习之路 - Python
    一、安装Python34Windows在Python官网(https://www.python.org/downloads/)下载安装包并安装。Python的默认安装路径是:C:\Python34配置环境变量:【右键计算机】--》【属性】-
    Python 学习之路 - Python
  • chatgpt的中文全称是什么
    chatgpt的中文全称是生成型预训练变换模型。ChatGPT是什么ChatGPT是美国人工智能研究实验室OpenAI开发的一种全新聊天机器人模型,它能够通过学习和理解人类的语言来进行对话,还能根据聊天的上下文进行互动,并协助人类完成一系列
    chatgpt的中文全称是什么
  • C/C++中extern函数使用详解
  • C/C++可变参数的使用
    可变参数的使用方法远远不止以下几种,不过在C,C++中使用可变参数时要小心,在使用printf()等函数时传入的参数个数一定不能比前面的格式化字符串中的’%’符号个数少,否则会产生访问越界,运气不好的话还会导致程序崩溃
    C/C++可变参数的使用
  • css样式文件该放在哪里
  • php中数组下标必须是连续的吗
  • Python 3 教程
    Python 3 教程 Python 的 3.0 版本,常被称为 Python 3000,或简称 Py3k。相对于 Python 的早期版本,这是一个较大的升级。为了不带入过多的累赘,Python 3.0 在设计的时候没有考虑向下兼容。 Python
    Python 3 教程
  • Python pip包管理
    一、前言    在Python中, 安装第三方模块是通过 setuptools 这个工具完成的。 Python有两个封装了 setuptools的包管理工具: easy_install  和  pip , 目前官方推荐使用 pip。    
    Python pip包管理
  • ubuntu如何重新编译内核
  • 改善Java代码之慎用java动态编译

目录