获取地址栏参数的方式

256 阅读1分钟

1.window.location.search

const params = new URLSearchParams(window.location.search);
params.get("token"); // 'xxxxxdflserjkeskdf'
params.get("page"); // '1'

2.用entries转成对的数组,然后用fromEntries转成对象格式

const params = new URLSearchParams("pageSize=100&page=1");
const entries = params.entries();
Object.fromEntries(entries); // {pageSize: 100, page: '1'}

3.同一个参数名多个值的情况

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

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

const url = new URL("https://stackabuse.com/search?pageSize=100&page=1");
const searchParams = url.searchParams;
searchParams.get("pageSize"); // '100'
searchParams.get("page"); // '1'

//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; // ''

5.手打柠檬茶,纯手写

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;
}