一个不错的JavaScript解析浏览器路径方法
2014-11-11 00:00
627 查看
JavaScript中有时需要用到当前的请求路径等涉及到url的情况,正常情况下我们可以使用location对象来获取我们需要的信息,本文从另外一个途径来解决这个问题,而且更加巧妙
方法如下:
使用方法如下:
方法如下:
function parseURL(url) { var a = document.createElement('a'); //创建一个链接 a.href = url; return { source: url, protocol: a.protocol.replace(':',''), host: a.hostname, port: a.port, 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('/') }; }
使用方法如下:
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' myURL.protocol; // = 'http' myURL.source; // = 'http://abc.com:8080/dir/index.html?id=255&m=hello#top'
相关文章推荐
- 一个不错的JavaScript解析浏览器路径方法
- 一个不错的JavaScript解析浏览器路径方法(转)
- 一个不错的JavaScript解析浏览器路径方法
- JavaScript,一个超级简单的方法判断浏览器的内核前缀
- 一个非常全面的javascript URL解析函数和分段URL解析方法
- 奥运五环(一个简单的的测试浏览器对javascript的解析速度)
- JavaScript,一个超级简单的方法判断浏览器的内核前缀
- console.log()不是JavaScript的一个方法,而是各浏览器提供的一个方法。
- JavaScript写一个方法把URL解析成对象.html
- 原生JavaScript常用本地浏览器存储方法五(LocalStorage+userData的一个浏览器兼容类)
- 一个不错的解析URL地址的JS方法,推荐一下
- 一个非常全面的javascript URL解析函数和分段URL解析方法
- 一个叫ddccbba.dll的浏览器查件-删除-方法
- 一个隐藏的Javascript的方法
- Apache BCEL 一个不错得测试方法技术
- 一个获取相对路径的方法(C#)
- 一个很有用的方法,可用根据一个类文件找到他的路径
- 整理的比较不错的JavaScript的方法和技巧第1/3页
- 为 Javascript 数组添加一个 inArray 方法
- 一个不错的用JavaScript实现的UBB编码函数