URL地址中的#符号使用说明_Javascript教程-查字典教程网
URL地址中的#符号使用说明
URL地址中的#符号使用说明
发布时间:2016-12-30 来源:查字典编辑
摘要:一般我们想让一个a标签点击后执行javascript代码,有以下几种写法:方式一:点击一这种方式的缺点就是点击后会在地址栏的URL后面加#号...

一般我们想让一个a标签点击后执行javascript代码,有以下几种写法:

方式一:<a href="#">点击一</a>

这种方式的缺点就是点击后会在地址栏的URL后面加#号,同时把页面移动到顶部,一般不建议使用。

方式二:<a href="javascript:void(0);">点击一</a>

这种方式避免了方式一的缺点,点击后对页面没有任何影响。但是有一个致命的缺点,就是在IE6下不能执行form对象的submit()方法,也不能执行跳转语句,比如

<a href="javascript:void(0);">点击一</a>

<a href="javascript:void(0);">点击一</a>

在IE6下就无效,换成href=”#”就能在IE6下正常执行。

方式三:<a href="###">点击一</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教程学习
    热门Javascript教程学习
    编程开发子分类