js 解析url

以前解析uri都是去找网上的代码,用起来不怎么顺手,刚好自己前段时间做项目的时候需要用到,于是就自己写了一个,欢迎个位提出宝贵意见。

getUrlParam (name) { //解析url
    var obj = {};
    var url_0=window.location.href;//获取url
    var url;
       if(url_0.indexOf('?')!=-1){
         url = url_0.split('?')[1].split('&');//通过&符分割为数组
       }else{
         console.log('url没有使用?传参');
         return false
       }   
    var nameList = [];
    url.forEach(function(item) {//遍历数组
      let tempArr = item.split('=');
      let key = decodeURIComponent(tempArr[0]);
      let val = decodeURIComponent(tempArr[1]);
      obj[key] = val;
      nameList.push(key);
    })
    if (nameList.indexOf(name) == -1) {
      console.log('url没传' + name);
      return false
    } else {
      return obj[name]
    }
  }

 

转载于:https://www.cnblogs.com/Black-Skin/p/8618270.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
处理 URL Query 参数可以使用 JavaScript 内置的 `URLSearchParams` 对象或者第三方 `querystring` 或 `lodash`。 以下是使用 `URLSearchParams` 对象的示例代码: ```javascript const params = new URLSearchParams(window.location.search); // 获取参数值 const foo = params.get('foo'); const bar = params.get('bar'); // 设置参数值 params.set('baz', '123'); // 删除参数 params.delete('foo'); // 将参数对象转换为字符串 const paramString = params.toString(); ``` 以下是使用 `querystring` 的示例代码: ```javascript const querystring = require('querystring'); const params = querystring.parse(window.location.search.slice(1)); // 获取参数值 const foo = params.foo; const bar = params.bar; // 设置参数值 params.baz = 123; // 删除参数 delete params.foo; // 将参数对象转换为字符串 const paramString = querystring.stringify(params); ``` 以下是使用 `lodash` 的示例代码: ```javascript const _ = require('lodash'); const params = _.chain(window.location.search.slice(1)) .split('&') .map(_.partial(_.split, _, '=', 2)) .fromPairs() .value(); // 获取参数值 const foo = params.foo; const bar = params.bar; // 设置参数值 params.baz = 123; // 删除参数 delete params.foo; // 将参数对象转换为字符串 const paramString = _.chain(params) .toPairs() .map(_.partial(_.join, _, '=', 2)) .join('&') .value(); ``` 以上三种方法都可以实现 URL Query 参数的处理,具体使用哪一种方法取决于个人喜好和项目需求。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值