写一个程序parse
,解析下面的queryString
,返回一个对象
console.log(parse('a=1&b=2&c=3')) // => { a: '1', b: '2', c: '3' }
console.log(parse('a&b&c')) // => {}
console.log(parse('a[name][second]=careteen&a[company]=sohu&b=y')) // => { a: { name: { second: 'careteen' }, company: 'sohu' }, b: 'y' }
console.log(parse('color=Deep%20Blue')) // => { color: 'Deep Blue' }
console.log(parse('a[0]=1&a[1]=2')) // => { a: [ '1', '2' ] }
首先要先了解url参数
的规则
&
或其他字符进行分割,且以=
分割键值对&
和=
分割时可能没有值=
后面的值可能已经encodeURIComponent
转码,需要解码a[name][second]=careteen&a[company]=sohu&b=y
,需要按层级设置对象a[0]=1&a[1]=2
,此时应该处理返回成数组针对上述分析其规则,解析一个URL需要考虑诸多情况。
下面给出具体实现
/**
* @desc 解析URL
* @param {String} str
* @param {Object} options
* @param {String} options.delimiter // 分隔符
*/
const parse = (str, options = {}) => {
let config = Object.assign({
delimiter: '&'
}, options)
return str.split(config.delimiter).reduce((ret, cur) => {
let [key, value] = cur.split('=')
if (!value) return ret
// ret[key] = value
deepSet(ret, key, value)
return ret
}, {})
}
辅助函数
/**
* @desc 辅助函数 深层级设置
*/
const deepSet = (ret, key, value) => {
/* eslint-disable */
let path = key.split(/[\[\]]/g).filter(item => !!item)
// console.log(path)
let i = 0
for (; i < path.length - 1; i++) {
if (ret[path[i]] === undefined) {
if (path[i + 1].match(/^\d+$/)) {
ret[path[i]] = []
} else {
ret[path[i]] = {}
}
}
ret = ret[path[i]]
}
ret[path[i]] = decodeURIComponent(value)
// console.log(ret)
}
测试用例
console.log(parse('a=1&b=2&c=3')) // => { a: '1', b: '2', c: '3' }
console.log(parse('a&b&c')) // => {}
console.log(parse('a[name][second]=careteen&a[company]=sohu&b=y')) // => { a: { name: { second: 'careteen' }, company: 'sohu' }, b: 'y' }
console.log(parse('color=Deep%20Blue')) // => { color: 'Deep Blue' }
console.log(parse('a[0]=1&a[1]=2')) // => { a: [ '1', '2' ] }
解析字符串看似简单,实则考察诸多知识点
reduce
去简化流程URL
规则满足各种需求扫码关注腾讯云开发者
领取腾讯云代金券
Copyright © 2013 - 2025 Tencent Cloud. All Rights Reserved. 腾讯云 版权所有
深圳市腾讯计算机系统有限公司 ICP备案/许可证号:粤B2-20090059 深公网安备号 44030502008569
腾讯云计算(北京)有限责任公司 京ICP证150476号 | 京ICP备11018762号 | 京公网安备号11010802020287
Copyright © 2013 - 2025 Tencent Cloud.
All Rights Reserved. 腾讯云 版权所有