发布于2022-12-03 15:15 阅读(1039) 评论(0) 点赞(27) 收藏(1)
在 URL 中,查询参数字符串值通常提供有关请求的信息,例如搜索参数或正在使用的对象的 ID。如果在前端处理任何业务或请求逻辑,了解如何从 URL 中检索查询字符串值非常重要。本文分享三种从 URL 获取参数的方法。
除 IE 11 之外的所有主要浏览器版本都支持该 URLSearchParams
接口。它通过解析 URL 的查询字符串并提供访问值的方法来工作。例如:
此接口的缺点之一是您必须仅将 URL 的查询字符串传递给它。如果您正在使用当前的浏览器 URL,这很容易做到,因为您只需通过 window.location.search
。 如果您使用任何其他 URL,则需要单独解析并传递查询字符串。
- const params = new URLSearchParams("q=devpoint&page=1");
- params.get("q"); // 'devpoint'
- params.get("page"); // '1'
要将查询参数解析为对象,请使用 URL.searchParams
的 .entries()
方法,该方法返回一个 Iterator
key/value
对,并将Object.fromEntries
其转换为对象。
- const params = new URLSearchParams("q=devpoint&page=1");
- const entries = params.entries();
- Object.fromEntries(entries); // {q: 'devpoint', page: '1'}
以参数的方式传递数组值,参数名称可以是同一个,如下的参数 uid
:
- const paramsString = "q=devpoint&uid=1&uid=3&uid=4";
- const searchParams = new URLSearchParams(paramsString);
-
- console.log(console.log(searchParams.getAll("uid"))); // [ '1', '3', '4' ]
除了 IE 11 之外,所有主要浏览器版本也都支持 URL
API。它提供了一种更灵活的 URL 解析方式,还提供了一种访问查询字符串值的方式。例如:
- const url = new URL("https://stackabuse.com/search?q=devpoint&page=1");
- const searchParams = url.searchParams;
- searchParams.get("q"); // 'devpoint'
- searchParams.get("page"); // '1'
url.searchParams
与 URLSearchParams
返回的实例对象类型相同。
上面的 url
对象也将 URL
的所有部分分解成各个部分。例如:
- url.href; // 'https://stackabuse.com/search?q=devpoint&page=1'
- url.origin; // 'https://stackabuse.com'
- url.protocol; // 'https:'
- url.host; // 'stackabuse.com'
- url.hostname; // 'stackabuse.com'
- url.port; // ''
- url.pathname; // '/search'
- url.search; // '?q=devpoint&page=2'
- url.hash; // ''
如果由于某种原因无法访问上述 API 或希望对解析有更多控制权,可以使用以下代码将查询字符串解析为对象。
- function getQueryParams(url) {
- const paramArr = url.slice(url.indexOf("?") + 1).split("&");
- const params = {};
- paramArr.map((param) => {
- const [key, val] = param.split("=");
- params[key] = decodeURIComponent(val);
- });
- return params;
- }
函数执行后的效果如下:
getQueryParams("https://stackabuse.com/search?q=devpoint&page=2"); // { q: 'devpoint', page: '2' }
原文链接:https://blog.csdn.net/m0_60153106/article/details/126761415
作者:麻辣小龙虾
链接:http://www.qianduanheidong.com/blog/article/459348/a2932cad744a65adc5f9/
来源:前端黑洞网
任何形式的转载都请注明出处,如有侵权 一经发现 必将追究其法律责任
昵称:
评论内容:(最多支持255个字符)
---无人问津也好,技不如人也罢,你都要试着安静下来,去做自己该做的事,而不是让内心的烦躁、焦虑,坏掉你本来就不多的热情和定力
Copyright © 2018-2021 前端黑洞网 All Rights Reserved 版权所有,并保留所有权利。 京ICP备18063182号-3
投诉与举报,广告合作请联系vgs_info@163.com或QQ3083709327
免责声明:网站文章均由用户上传,仅供读者学习交流使用,禁止用做商业用途。若文章涉及色情,反动,侵权等违法信息,请向我们举报,一经核实我们会立即删除!