获取 URL 并解析查询参数

🌙
手机阅读
本文目录结构

需求

获取 url 地址里面查询情况(可能包含 Hash)

https://www.axihe.com/?name=anbang&age=30#%E6%A0%87%E7%AD%BE
{
    "name":"anbang",
    "age":"30",
    "hash":"标签"
}

每一项都可能有,也可能没有

代码

var str1 = 'https://www.axihe.com/?name=anbang&age=30#%E6%A0%87%E7%AD%BE';
var str2 = 'https://www.axihe.com/?name=安邦&age=三十#%E6%A0%87%E7%AD%BE';

function parseUrl(url) {
    let obj = {};
    // 除了?=&#以外都是有效的值
    url.replace(/([^?=&#]+)=([^?=&#]+)/g, (...arg) => {
        // console.log('arg', arg);
        obj[arg[1]] = decodeURIComponent(arg[2]);
    });

    url.replace(/#([^?=&#]+)/g, (...arg) => {
        // console.log('arg', arg);
        obj['HASH'] = decodeURIComponent(arg[1]);
    });
    return obj;
}

console.log(parseUrl(str1));//{name: "anbang", age: "30", HASH: "标签"}
console.log(parseUrl(str2));//{name: "安邦", age: "三十", HASH: "标签"}

AXIHE / 精选资源

浏览全部教程

面试题

学习网站

前端培训
自己甄别

前端书籍

关于朱安邦

我叫 朱安邦,阿西河的站长,在杭州。

以前是一名平面设计师,后来开始接接触前端开发,主要研究前端技术中的JS方向。

业余时间我喜欢分享和交流自己的技术,欢迎大家关注我的 Bilibili

关注我: Github / 知乎

于2021年离开前端领域,目前重心放在研究区块链上面了

我叫朱安邦,阿西河的站长

目前在杭州从事区块链周边的开发工作,机械专业,以前从事平面设计工作。

2014年底脱产在老家自学6个月的前端技术,自学期间几乎从未出过家门,最终找到了满意的前端工作。更多>

于2021年离开前端领域,目前从事区块链方面工作了