Javascript基础:解析 URL Params 为对象

本文介绍了一种解析URL中携带的参数的方法,并提供了一个JavaScript函数实现。该函数能够处理重复的键值、中文编码及未指定值的情况。

一、解析 URL Params 为对象

let url = 'http://www.domain.com/?user=anonymous&id=123&id=456&city=%E5%8C%97%E4%BA%AC&enabled'; parseParam(url) 
/* 结 果 
{ user: 'anonymous', 
id: [ 123, 456 ], // 重复出现的 key 要组装成数组,能被转成数字的就转成数字类型 
city: '北京', // 中⽂需解码 
enabled: true, // 未指定值得 key 约定为 true 
}*/
function parseParam(url) { 
const paramsStr = /.+\?(.+)$/.exec(url)[1]; // 将 ? 后⾯的字符串取出来 
const paramsArr = paramsStr.split('&'); // 将字符串以 & 分割后存到数组 中
let paramsObj = {}; 
// 将 params 存到对象中 
paramsArr.forEach(param => { if (/=/.test(param)) { // 处理有 value 的参数 
let [key, val] = param.split('='); // 分割 key 和 value 
val = decodeURIComponent(val); // 解 码 
val = /^\d+$/.test(val) ? parseFloat(val) : val; // 判断是否转为数字 
if (paramsObj.hasOwnProperty(key)) { // 如果对象有 key,则添加⼀个值 
paramsObj[key] = [].concat(paramsObj[key], val); 
} else { // 如果对象没有这个 key,创建 key 并设置值 
paramsObj[key] = val; 
} 
} else { // 处理没有 value 的参数 
paramsObj[param] = true; } })return paramsObj; 
}
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值