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

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

方式三:<a href="###" onclick="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读取内容。

相关文章

  • 分享javascript、jquery实用代码段

    分享javascript、jquery实用代码段

    这篇文章主要为大家分享了javascript、jquery实用代码段,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2016-10-10
  • js省市区级联查询(插件版&无插件版)

    js省市区级联查询(插件版&无插件版)

    这篇文章主要为大家详细介绍了js省市区级联查询,包括插件版和无插件版,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2017-03-03
  • JS中关于filter()方法的使用及说明

    JS中关于filter()方法的使用及说明

    这篇文章主要介绍了JS中关于filter()方法的使用及说明,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2023-05-05
  • SwfUpload在IE10上不出现上传按钮的解决方法

    SwfUpload在IE10上不出现上传按钮的解决方法

    在测试中发现使用了SwfUpload实现的无刷新上传功能,在IE10上竟然无法使用了,难道SwfUpload不支持吗?下面与大家分享下通过修改SwfUplad.JS文件让其支持ie10
    2013-06-06
  • javascript实现画板功能

    javascript实现画板功能

    这篇文章主要为大家详细介绍了javascript实现画板功能,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2020-04-04
  • JavaScript相等判断的避坑实战指南

    JavaScript相等判断的避坑实战指南

    JavaScript中的相等性判断,在项目开发中,我经常会遇到,今天我们一起探讨下,下面这篇文章主要给大家介绍了关于JavaScript相等判断的避坑实战指南,文中通过实例代码介绍的非常详细,需要的朋友可以参考下
    2022-08-08
  • js实现div的切换特效上一个下一个

    js实现div的切换特效上一个下一个

    实现div切换的方法有很多,下面为大家介绍下使用js是如何实现的
    2014-02-02
  • JS通过调用微信API实现微信支付功能的方法示例

    JS通过调用微信API实现微信支付功能的方法示例

    这篇文章主要介绍了JS通过调用微信API实现微信支付功能的方法,结合具体实例形式分析了javascript微信支付接口的调用方法与相关注意事项,需要的朋友可以参考下
    2017-06-06
  • 判断是否安装flash player及当前版本的JS代码

    判断是否安装flash player及当前版本的JS代码

    本文为大家讲述下如何使用jsJS判断是否安装flash player及版本,下面的处理代码或许对大家有所帮助,感兴趣的朋友可以参考下,希望对大家有所帮助
    2013-08-08
  • 子窗体与父窗体传值示例js代码

    子窗体与父窗体传值示例js代码

    子窗体与父窗体之见互相传值实现使用中很频繁,本文以一个小示例抛砖引玉,希望大家可以举一反三
    2013-08-08

最新评论