JS获取地址栏中url的参数,返回一个对象

在工作中,时常会有从地址栏中拿取对应的参数,当参数过多时,我们会考虑封装成一个方法,将参数放在对象中返回,这样获取会更加方便,下面列出了两中方法。

  • 第一种
//路径 https://editor.csdn.net/md?articleId=1&&articleNum=1&opt=edit
getUrlParams = () => {
    let url = window.location.search;//?articleId=1&&articleNum=1&opt=edit
    let index = url.indexOf('?')
    let obj = {}
    if (index !== -1) {
      let str = url.substr(1)
      let arr = str.split('&')
      for (let i = 0; i < arr.length; i++) {
        obj[arr[i].split('=')[0]] = arr[i].split('=')[1]
      }
    }
    return obj//{articleId: "1", articleNum: "1", opt: "edit"}
  }
  • 第二种
 getUrlParams =  locationSearch=> {
    var obj = {};
    var search = locationSearch;
    search = /\?/.test(search) && search.split("?")[1];// \? 表示一个 ? 字符
    var searchs = /\&/.test(search) ? search.split("&") : [search];
    for (var i = 0; i < searchs.length; i++) {
        if (/\=/.test(searchs[i])) {
            var item = searchs[i].split("=");
            params[item[0]] = item[1];
        };
    };
    return obj;
};
  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值