• 三种获取URL参数值的方法


    在 URL 中,查询参数字符串值通常提供有关请求的信息,例如搜索参数或正在使用的对象的 ID。如果在前端处理任何业务或请求逻辑,了解如何从 URL 中检索查询字符串值非常重要。本文分享三种从 URL 获取参数的方法。

    URLSearchParams

    除 IE 11 之外的所有主要浏览器版本都支持该 URLSearchParams 接口。它通过解析 URL 的查询字符串并提供访问值的方法来工作。例如:

    此接口的缺点之一是您必须仅将 URL 的查询字符串传递给它。如果您正在使用当前的浏览器 URL,这很容易做到,因为您只需通过 window.location.search。 如果您使用任何其他 URL,则需要单独解析并传递查询字符串。

    1. const params = new URLSearchParams("q=devpoint&page=1");
    2. params.get("q"); // 'devpoint'
    3. params.get("page"); // '1'

    要将查询参数解析为对象,请使用 URL.searchParams.entries()方法,该方法返回一个 Iterator key/value 对,并将Object.fromEntries其转换为对象。

    1. const params = new URLSearchParams("q=devpoint&page=1");
    2. const entries = params.entries();
    3. Object.fromEntries(entries); // {q: 'devpoint', page: '1'}

    以参数的方式传递数组值,参数名称可以是同一个,如下的参数 uid

    1. const paramsString = "q=devpoint&uid=1&uid=3&uid=4";
    2. const searchParams = new URLSearchParams(paramsString);
    3. console.log(console.log(searchParams.getAll("uid"))); // [ '1', '3', '4' ]

    URL

    除了 IE 11 之外,所有主要浏览器版本也都支持 URL API。它提供了一种更灵活的 URL 解析方式,还提供了一种访问查询字符串值的方式。例如:

    1. const url = new URL("https://stackabuse.com/search?q=devpoint&page=1");
    2. const searchParams = url.searchParams;
    3. searchParams.get("q"); // 'devpoint'
    4. searchParams.get("page"); // '1'

    url.searchParamsURLSearchParams 返回的实例对象类型相同。

    上面的 url 对象也将 URL 的所有部分分解成各个部分。例如:

    1. url.href; // 'https://stackabuse.com/search?q=devpoint&page=1'
    2. url.origin; // 'https://stackabuse.com'
    3. url.protocol; // 'https:'
    4. url.host; // 'stackabuse.com'
    5. url.hostname; // 'stackabuse.com'
    6. url.port; // ''
    7. url.pathname; // '/search'
    8. url.search; // '?q=devpoint&page=2'
    9. url.hash; // ''

    纯JS

    如果由于某种原因无法访问上述 API 或希望对解析有更多控制权,可以使用以下代码将查询字符串解析为对象。

    1. function getQueryParams(url) {
    2. const paramArr = url.slice(url.indexOf("?") + 1).split("&");
    3. const params = {};
    4. paramArr.map((param) => {
    5. const [key, val] = param.split("=");
    6. params[key] = decodeURIComponent(val);
    7. });
    8. return params;
    9. }

    函数执行后的效果如下:

    getQueryParams("https://stackabuse.com/search?q=devpoint&page=2"); // { q: 'devpoint', page: '2' }
  • 相关阅读:
    笨蛋学算法之LeetCodeHot100_3_最长连续序列(Java)
    Canonical标签在SEO中重要作用
    消费品行业报告:化妆品容器市场现状研究分析与发展前景预测
    基于python的学生成绩管理系统毕业设计源码071143
    PackagingTool_x64_v2.0.1.0图片转档打包二进制文件合并字库生成图片软件介绍
    python环境移植,制作可以移植的python环境
    别再用 System.currentTimeMillis 统计耗时了,太 Low,试试 Spring Boot 源码在用的 StopWatch吧,够优雅!
    ESP32网络开发实例-WebSocket服务器
    【备忘录】docker-maven-plugin 使用
    【infiniband】infiniband和RDMA
  • 原文地址:https://blog.csdn.net/m0_60153106/article/details/126761415