广告
返回顶部
首页 > 资讯 > 精选 >如何使用原生JS获取URL链接参数
  • 365
分享到

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

2023-06-29 13:06:14 365人浏览 八月长安
摘要

这篇文章将为大家详细讲解有关如何使用原生js获取URL链接参数,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。1. 获取方式总结利用原生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链接参数”这篇文章就分享到这里了,希望以上内容可以对大家有一定的帮助,使各位可以学到更多知识,如果觉得文章不错,请把它分享出去让更多的人看到。

--结束END--

本文标题: 如何使用原生JS获取URL链接参数

本文链接: https://www.lsjlt.com/news/325015.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

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

下载Word文档
猜你喜欢
  • 如何使用原生JS获取URL链接参数
    这篇文章将为大家详细讲解有关如何使用原生JS获取URL链接参数,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。1. 获取方式总结利用原生JS获取URL链接参数的方法也有好几种,今天我们依次来讲解常见的几种:...
    99+
    2023-06-29
  • 原生JS获取URL链接参数的几种常见方法
    前言 作为一个前端开发,我们很多时候都需要对URL进行操作和处理,最常见的一种就是获取URL链接中携带的参数值了。使用框架开发的小伙伴可能会觉得这很简单,因为框架提供了很多方法让我们...
    99+
    2022-11-13
  • js如何获取URL中的参数
    这篇文章主要介绍js如何获取URL中的参数,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!获取 URL 中的参数这个需求在三大框架的时代应用貌似不多了,不过面试中问的还是蛮多的,了解一下是好的简单实现var ...
    99+
    2023-06-27
  • JS如何获取URL中的Query参数
    目录JS获取URL的Query参数需求描述实现一实现二JS获取URL上的指定参数总结JS获取URL的Query参数 需求描述 获取 URL 中的 Query 参数,例如: https...
    99+
    2023-01-17
    JS Query参数 JS获取URL的Query参数 JS获取Query参数
  • 使用js获取url中的参数并返回一个对象方式
    目录js获取url中的参数并返回一个对象思路js解析url中的参数——返回对象需求代码一点思路总结js获取url中的参数并返回一个对象 今天写一个原生的htm...
    99+
    2023-01-17
    js获取url的参数 js返回对象 js获取参数
  • 如何在Jersey中使用Restful接口获取参数
    如何在Jersey中使用Restful接口获取参数?相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。1.@PathParam使用该注释获取参数时可以获取URI中制定规则的参数例如:...
    99+
    2023-06-15
  • 如何使用原生JS获取select元素选中的value和text值
    本篇内容主要讲解“如何使用原生JS获取select元素选中的value和text值”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“如何使用原生JS获取select元素选中的value和text值”...
    99+
    2023-06-29
  • 微信小程序直播如何获取分享卡片链接参数
    这篇文章主要介绍“微信小程序直播如何获取分享卡片链接参数”,在日常操作中,相信很多人在微信小程序直播如何获取分享卡片链接参数问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”微信小程序直播如何获取分享卡片链接参数...
    99+
    2023-06-26
  • 使用flask如何获取post请求参数
    目录前言概述1. application/jsonhttp 请求报文格式如下:使用curlpostman 请求flask如何获取请求体呢2. application/x-www-fo...
    99+
    2022-11-11
  • Spring MVC如何使用@RequestParam注解获取参数
    目录使用@RequestParam注解获取参数@RequestParam无法获取参数使用@RequestParam注解获取参数 创建Hello控制器类 package com.c...
    99+
    2022-11-12
  • @RequestMapping 如何使用@PathVariable 从URI中获取参数
    目录@RequestMapping 使用@PathVariable 从URI中获取参数URI中的请求参数定义URL变量规则获取URI变量定义多个URL变量匹配正则表达式SpringM...
    99+
    2022-11-12
  • 如何在python中使用sys模块获取参数
    本篇文章给大家分享的是有关如何在python中使用sys模块获取参数,小编觉得挺实用的,因此分享给大家学习,希望大家阅读完这篇文章后可以有所收获,话不多说,跟着小编一起来看看吧。1、 sys.argv获取脚本传递的所有参数,返回一个列表。列...
    99+
    2023-06-15
  • 如何使用java过滤器获取所有参数值
    要使用Java过滤器获取所有参数值,可以按照以下步骤进行操作:1. 创建一个类实现`javax.servlet.Filter`接口,...
    99+
    2023-09-06
    java
  • Vue3使用vue-router如何实现路由跳转与参数获取
    目录vue-router实现路由跳转与参数获取路由跳转和传参路由跳转三种方法的总结一、第一种二、第二种三、第三种vue-router实现路由跳转与参数获取 路由跳转和传参 impor...
    99+
    2022-11-13
  • 使用controller接收js传过来的参数问题如何解决
    本文小编为大家详细介绍“使用controller接收js传过来的参数问题如何解决”,内容详细,步骤清晰,细节处理妥当,希望这篇“使用controller接收js传过来的参数问题如何解决”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一...
    99+
    2023-07-05
  • vue中如何使用echarts实现动态数据绑定及获取后端接口数据
    本篇内容主要讲解“vue中如何使用echarts实现动态数据绑定及获取后端接口数据”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“vue中如何使用echarts实现动态数据绑定及获取后端接口数据”...
    99+
    2023-07-02
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作