在 URL 中,查詢參數字元串值通常提供有關請求的資訊,例如搜尋參數或正在使用的對象的 ID。如果在前端處理任何業務或請求邏輯,了解如何從 URL 中檢索查詢字元串值非常重要。本文分享三種從 URL 擷取參數的方法。
URLSearchParams
除 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' ]
URL
除了 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; // ''
純JS
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'