JS解析url

@param {string} url 完整的URL地址
*@returns {object} 自定义的对象

*@description 用法示例:var myURL = parseURL('http://abc.com:8080/dir/index.html?id=255&m=hello#top');

myURL.file='index.html'

myURL.hash= 'top'

myURL.host= 'abc.com'

myURL.query= '?id=255&m=hello'

myURL.params= Object = { id: 255, m: hello }

myURL.path= '/dir/index.html'

myURL.segments= Array = ['dir', 'index.html']

myURL.port= '8080'

yURL.protocol= 'http'

myURL.source= 'http://abc.com:8080/dir/index.html?id=255&m=hello#top'

*/
代码部分

function parseURL(url) {
 var a =  document.createElement('a');
 a.href = url;
 return {
 source: url,
 protocol: a.protocol.replace(':',''),             //网络协议http:
 host: a.hostname,                                 //主机<span style="color: rgb(17, 17, 17); font-family: Verdana, Arial, Helvetica, sans-serif; font-size: 13px; line-height: 23.4px;">URL 的主机部分</span><span style="color: rgb(17, 17, 17); font-family: Verdana, Arial, Helvetica, sans-serif; font-size: 13px; line-height: 23.4px;">返回:www.。。。.com</span>
 port: a.port,                                     //端口‘8080'
 query: a.search,                                  //查询参数?。。。#
 params: (function(){
     var ret = {},
         seg = a.search.replace(/^\?/,'').split('&'),
         len = seg.length, i = 0, s;
     for (;i<len;i++) {
         if (!seg[i]) { continue; }
         s = seg[i].split('=');
         ret[s[0]] = s[1];
     }
     return ret;
 })(),
 file: (a.pathname.match(/\/([^\/?#]+)$/i) || [,''])[1],
 hash: a.hash.replace('#',''),                                //锚点
 path: a.pathname.replace(/^([^\/])/,'/$1'),                  //路径部分
 relative: (a.href.match(/tps?:\/\/[^\/]+(.+)/) || [,''])[1],
 segments: a.pathname.replace(/^\//,'').split('/')
 };
}


  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 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、付费专栏及课程。

余额充值