java获取a标签的URL_利用a标签自动解析URL

本文介绍了一个JavaScript函数,用于解析URL并返回其组成部分,如协议、主机名、端口、查询参数等。

对于window.location,我们比较熟悉,它有protocol,hostname,host,port,search,hash,href,pathname等属性,a标签也和window.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||‘80‘,

query: a.search,

params: (function(){

var ret = {},

seg = a.search.replace(/^\?/,‘‘).split(‘&‘),

len = seg.length, i = 0, s;

for (;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(‘/‘)

};

}

测试地址

console.log(parseURL("http://www.w3school.com.cn/jsref/dom_obj_anchor.asp?type=2#id2"));

结果如下

69c5a8ac3fa60e0848d784a6dd461da6.png

1 {

2 file: "dom_obj_anchor.asp",

3 hash: "id2",

4 host: "www.w3school.com.cn",

5 params: {type: "2"},

6 path: "/jsref/dom_obj_anchor.asp",

7 port: "80",

8 protocol: "http",

9 query: "?type=2",

10 relative: "/jsref/dom_obj_anchor.asp?type=2#id2",

11 segments: [0: "jsref",1: "dom_obj_anchor.asp"],

12 source: "http://www.w3school.com.cn/jsref/dom_obj_anchor.asp?type=2#id2"

13 }

69c5a8ac3fa60e0848d784a6dd461da6.png

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值