备份:这是2009年2月12号的日志.
昨天同事遇到了一个奇怪的问题,很多人喜欢这样写<a href="javas
cript:void(0)" onclick="functionFoo()">label</a>
意思是点击label时会调用functionFoo(),一般的调用是不会有问题的。
但如果这个函数会使页面发生跳转的话,在ie6下就会出问题(ie7,FF3都没问题)。现象为不会发生跳转。
代码如:
function functionFoo()
{
var frm = $("from");//得到某个from,method为post。
frm.submit();
}
当点击label时,在ie6下是不会发生跳转的,但form是已经提交到服务器端了,只是页面没有刷新。
解决方法有两个:
<a href="#" onclick="xxxx">,不要用void(0),用"#"代替,缺点是当前页会跳到顶部。
<a href="javascript:void(0)" onclick="foo();return false;">或者不用<a> 在onclick的调用上,最后加上return false;就可以正常工作了.
意思是点击label时会调用functionFoo(),一般的调用是不会有问题的。
但如果这个函数会使页面发生跳转的话,在ie6下就会出问题(ie7,FF3都没问题)。现象为不会发生跳转。
代码如:
function functionFoo()
{
var frm = $("from");//得到某个from,method为post。
frm.submit();
}
当点击label时,在ie6下是不会发生跳转的,但form是已经提交到服务器端了,只是页面没有刷新。
分析
估计是ie认为这个href="javascript:void(0)"表示一定不会发生跳转的,所以就算触发了onclick的函数并提交了form也不需要刷新当前页。总之我觉得是ie6的bug,ie7和FireFox3都没有这个问题。解决方法有两个:
<a href="#" onclick="xxxx">,不要用void(0),用"#"代替,缺点是当前页会跳到顶部。
<a href="javascript:void(0)" onclick="foo();return false;">或者不用<a> 在onclick的调用上,最后加上return false;就可以正常工作了.
本文探讨了在IE6浏览器中使用特定<a>标签时遇到的问题,即点击后不会触发预期的页面跳转行为。文章分析了问题的原因,并提供了两种可行的解决方案。

11万+

被折叠的 条评论
为什么被折叠?



