(六) 地址栏相关字段解析

1. 在地址栏添加参数/修改参数 返回新的拼接结果

function addUrlParams(args, search = window.location.search || '') {
    if (Object.prototype.toString.call(args) !== '[object Object]') {
        throw new Error('addUrlParams(): 参数类型不正确')
        return
      }
      var obj = {}
      if (search) {
        // 否则 search.split('?') 报错
        var search = search.split('?')[1]
        const arr = search.split('&').forEach(element => {
          var itemArr = element.split('=')
          var key = itemArr[0]
          var value = itemArr[1]
          obj[key] = decodeURIComponent(value)
        });
      }
      var arrResult = []
      var resultObj = Object.assign(obj, args)
      for (var item in resultObj) {
        arrResult.push(item + '=' + resultObj[item])
      }
      return '?' + arrResult.join('&')
    }
    console.log(addUrlParams({ ab: '周芳冰'}, '?aaa=2333'))

先将现有的地址栏参数转化为对象,将传入的参数对象与现有的参数对象合并,合并可以做到(去重:后一个覆盖前一个,起到了修改的作用/合并)

2. 移除浏览器参数

function removeUrlParams(key, search = window.location.search || '') {
      if (typeof key !== 'string') {
        throw new Error('addUrlParams(): 参数类型不正确')
        return
      }
      var obj = {}
      if (search) {
        var search = search.split('?')[1]
        const arr = search.split('&').forEach(element => {
          var itemArr = element.split('=')
          var key = itemArr[0]
          var value = itemArr[1]
          obj[key] = decodeURIComponent(value)
        });
      }
      delete obj[key]
      var arrResult = []
      for (var item in obj) {
        arrResult.push(item + '=' + obj[item])
      }
      return '?' + arrResult.join('&')
    }
    console.log(removeUrlParams('aa', '?aaa=2333&bbb=344&ccc=33434'))

 

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值