定义一个方法获取一段携带参数的 url 中 key 对应的 value

本文介绍两种从URL中解析参数的方法,并通过实例展示了如何将参数转换为对象以方便使用。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

思路

给定一段 url 地址,取出后面的参数转换成参数对象,然后再通过 key 找到对应的 value

方法一

let url = 'https://xxxx.com?a=1&b=2&c=&d'
function fn(url, key) {
    let arr = url.substr(url.indexOf('?')+1).split('&')
    let newObj = arr.reduce((obj, item)=>{
        obj[item.split('=')[0]] = item.split('=')[1]
        return obj
    }, {})
    return newObj[key]
}
        
console.log(fn(url, 'd')) // undefined

方法二

let url = 'https://xxxx.com?a=1&b=2&c=zs&d=李';
function p_urlParse(url, key) {
    let obj = {};
    let reg = /[?&][^?&]+=[^?&]+/g;
    let arr = url.match(reg);
    if (arr) {
        arr.forEach((item) => {
        let tempArr = item.substring(1).split('=');
        let key = decodeURIComponent(tempArr[0]);
        let val = decodeURIComponent(tempArr[1]);
        obj[key] = val;
        })
    }
    return obj[key];
};

console.log(p_urlParse(url, 'c')) // 'zs'
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值