在 URL 中,查询参数字符串值通常提供有关请求的信息,例如搜索参数或正在使用的对象的 ID。如果在前端处理任何业务或请求逻辑,了解如何从 URL 中检索查询字符串值非常重要。本文分享三种从 URL 获取参数的方法。
window.location.href
通过window.location.href获取当前url路径
URLSearchParams
必须将当前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'}
URL
除了 IE 11 之外,所有主要浏览器版本也都支持 URL
API。它提供了一种更灵活的 URL 解析方式,还提供了一种访问查询字符串值的方式。例如:
const url = new URL("https://stackabuse.com/search?q=devpoint&page=1");
const searchParams = url.searchParams;
纯js
如果由于某种原因无法访问上述 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' }