html a href 绝对路径,javascript中使用a标签获取当前目录的绝对路径方法

一谈到路径相关的问题,大家都会往window.location上想,确实这个对象提供了相当多的路径信息,其中常用的就包括:

7c616de60cf7bcad828af9ca43effed4.png

1.location.href:当前页面的完整url

2.location.pathname:当前url中的路径名

3.location.hash:当前url中的锚点

4.location.search:当前url中的查询参数

然而,location没有一个属性能直接获得当前目录(不含文件名)的绝对路径。通过google我发现了一些错误的方法,比如说把url通过“/”分离成数组,把数组的***一项去掉以后再连接成字符串。但如果url中没有指定文件名,结果就大错特错了。

根据以往编码的经验,a元素的href属性总是会返回绝对路径,也就是说它具有把相对路径转成绝对路径的能力。使用下面的代码尝试了一下,果然成了:

var a = document.createelement('a');

a.href = './';

alert(a.href);

a = null;

很不幸地,此方法在老旧的ie 6/7下无效,当执行alert(a.href)时,弹出的仍然是“./”。后来,我发现在stackoverflow上也有人提出了这个问题,而解决方法也是很简单的,只要把a通过innerhtml注入就可以了:

代码如下:

var div = document.createelement('div');

div.innerhtml = ';

alert(div.firstchild.href);

div = null;

有人可能会问:为何不用正则表达式?我的答案是:要考虑有无文件名的情况、有无锚点的情况、有无查询参数的情况,这条正则表达式可能会挺复杂的。

【责任编辑:wangxueyan TEL:(010)68476606】

点赞 0

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值