URL地址中的#符号使用说明

下面的内容介绍了#号的使用,因为在url中多个#号代表不同的意义与区别。
一般我们想让一个a标签点击后执行javascript代码,有以下几种写法:  
方式一:<a href="#" οnclick="alert(1);">点击一</a> 
这种方式的缺点就是点击后会在地址栏的URL后面加#号,同时把页面移动到顶部,一般不建议使用。
方式二:<a href="javascript:void(0);" οnclick="alert(1);">点击一</a> 
这种方式避免了方式一的缺点,点击后对页面没有任何影响。但是有一个致命的缺点,就是在IE6下不能执行form对象的submit()方法,也不能执行跳转语句,比如  
<a href="javascript:void(0);" οnclick="document.forms[0].submit();">点击一</a>  
<a href="javascript:void(0);" οnclick="window.location.href='http://www.google.com';">点击一</a>  
在IE6下就无效,换成href=”#”就能在IE6下正常执行。  

方式三:<a href="###" οnclick="alert(1);">点击一</a> 
点击后虽然会在地址栏的URL后面加三个#号,但是不会影响滚动条,同时在IE6下也能执行form对象的submit()方法与跳转语句,算是一个比较折中的方法。  

结论:我个人认为如果执行的javascript方法中需要提交表单、跳转页面,则用方式三,其它情况都用方式二。  

另:这又附带引出另一个问题,一般重新加载当前页面用如下的javascript代码:  
window.location.href = window.location.href;  
但是当URL地址中含有#时,上述代码无效,于是需要用如下代码:  
window.location.href = window.location.href.split('#')[0];  
将URL地址以#符号分割开,取第一部分即可。  

在很多情况下/index.htm#desc,后面的desc可能就是参数,不容易的参数显示不同的内容,不是简单锚点,而是ajax读取内容。
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值