[心缘地方]同学录
首页 | 功能说明 | 站长通知 | 最近更新 | 编码查看转换 | 代码下载 | 常见问题及讨论 | 《深入解析ASP核心技术》 | 王小鸭自动发工资条VBA版
登录系统:用户名: 密码: 如果要讨论问题,请先注册。

[转帖]jquery1.3.2在IE8下toggle()的Bug,存在隐藏后无法显示的问题

上一篇:[转帖]一字锁基本功练习之我见-------皖宁锁艺 王
下一篇:[备忘]spring的DriverManagerDataSource配置里,写oracle的属性

添加日期:2014/4/3 10:53:58 快速返回   返回列表 阅读2868次
原文:http://www.smuwcwt.com/archives/323
另一篇:http://www.linuxfly.org/post/523/

该Bug只在IE8非兼容模式下会存在,目前已经找到多篇关于此Bug的介绍,具体见文末!

版本号: jquery1.3.2

浏览器: IE8

问 题: toggle()存在hide后无法show的问题

代 码:


<script type="text/javascript"> 
$(document).ready(function(){ 
$(‘#tbl td’).bind(‘click’,function(){ 
        $(this).parent().next().toggle(); 
    }) 
}) 
</script>
<table id="tbl"> 
<tr><td>LINE1</td></tr> 
<tr><td>LINE2</td></tr> 
<tr><td>LINE3</td></tr> 
<tr><td>LINE4</td></tr> 
</table>


描 述: 当单击LINE1时,LINE2会隐藏,但再次单击时,却无法正常显示了!


修 复1:  利用1.3.2最新加入的方法toggle(switch)


<script type="text/javascript"> 
$(document).ready(function(){ 
$(‘#tbl td’).bind(‘click’,function(){ 
        $(this).parent().next().toggle($(this).parent().next().css(‘display’)==’none’); 
    }) 
}) 
</script>
<table id="tbl"> 
<tr><td>LINE1</td></tr> 
<tr><td>LINE2</td></tr> 
<tr><td>LINE3</td></tr> 
<tr><td>LINE4</td></tr> 
</table>



修 复2:  利用toggleClass切换样式


<style> 
.hidden{ display:none; } 
</style> 
<script type="text/javascript"> 
$(document).ready(function(){ 
$(‘#tbl td’).bind(‘click’,function(){ 
        $(this).parent().next().toggleClass(‘hidden’); 
    }) 
}) 
</script>
<table id="tbl"> 
<tr><td>LINE1</td></tr> 
<tr><td>LINE2</td></tr> 
<tr><td>LINE3</td></tr> 
<tr><td>LINE4</td></tr> 
</table>



代码比较少,如需要测试,请自行Copy Code, and Import 相关版本的jquery!
 

评论 COMMENTS
没有评论 No Comments.

添加评论 Add new comment.
昵称 Name:
评论内容 Comment:
验证码(不区分大小写)
Validation Code:
(not case sensitive)
看不清?点这里换一张!(Change it here!)
 
评论由管理员查看后才能显示。the comment will be showed after it is checked by admin.
CopyRight © 心缘地方 2005-2999. All Rights Reserved