IE9的BUG?jQuery的BUG?
2013-07-14 11:01
176 查看
本文转载自http://big-student.iteye.com/blog/1898213
在IE9和IE10中,当对一个html的样式初始了一个很大的left或者top时,使用jQuery的offset()或者jQuery UI的position重新定位会出现left或者top计算错误,造成元素离正确的位置很远。看例子:
Html代码
<body style="overflow: hidden">
<div id="window" style=" display: block; position: absolute; left:214749px; top:127px;padding: 0; overflow: hidden; height: 400px; width: 800px; z-index: 10000;border:1px solid red">
</div>
<script>
$(function(){
$("body").height($(window).height()).width($(window).width());
$("#window").offset({left:282, top:127});
})
</script>
发现window的left为-429214.73px,而如果使用css方法不会有问题,即 $("#window_1").css({left:"282px", top:"127px"}); 如果将其中的left:214749px改为214748px则可定位成功。
问题原因:
调试了jQuery源代码发现是window.getComputedStyle(elem, null)在IE9和IE10中对left和top设置了大于214748的值时,getComputedStyle会返回错误的计算结果,造成jquery的offset方法错误,如果你使用了jQuery ui的position方法,因为offset方法的问题今儿引起position定位错误问题。
结论:
该bug是ie9和ie10对定位过大的设置getComputedStyle返回错误的大小引起的。
在IE9和IE10中,当对一个html的样式初始了一个很大的left或者top时,使用jQuery的offset()或者jQuery UI的position重新定位会出现left或者top计算错误,造成元素离正确的位置很远。看例子:
Html代码
<body style="overflow: hidden">
<div id="window" style=" display: block; position: absolute; left:214749px; top:127px;padding: 0; overflow: hidden; height: 400px; width: 800px; z-index: 10000;border:1px solid red">
</div>
<script>
$(function(){
$("body").height($(window).height()).width($(window).width());
$("#window").offset({left:282, top:127});
})
</script>
发现window的left为-429214.73px,而如果使用css方法不会有问题,即 $("#window_1").css({left:"282px", top:"127px"}); 如果将其中的left:214749px改为214748px则可定位成功。
问题原因:
调试了jQuery源代码发现是window.getComputedStyle(elem, null)在IE9和IE10中对left和top设置了大于214748的值时,getComputedStyle会返回错误的计算结果,造成jquery的offset方法错误,如果你使用了jQuery ui的position方法,因为offset方法的问题今儿引起position定位错误问题。
结论:
该bug是ie9和ie10对定位过大的设置getComputedStyle返回错误的大小引起的。
相关文章推荐
- jquery ajaxFileUpload 插件在IE9中的bug修复
- jQuery 1.5.1 发布,全面支持IE9 修复大量bug
- jQuery 1.5.1 发布,全面支持IE9 修复大量bug
- jQuery ajaxFileUpload.js 插件 ie9 下bug 修复
- Tinymce+jQuery.Validation使用产生的BUG
- jquery.validate.js 1.7 的BUG
- jquery hover 切换时间,连续切换BUG,解决办法。
- 修复jquery.treeview的增加子节点的方法的bug
- 笔记 jquery 的一个bug解决方法积累
- JQuery find方法Bug
- 解决jQuery 浏览器版本判断BUG
- jQuery datepicker和jQuery validator 共用时bug
- ie9 ff11, javascript 数组处理的一个bug
- 关于JQuery的一个Bug
- jquery dialog width 有一个bug
- jQuery实现全选、全不选和反选,没有只能选一次的bug
- Jquery delegate 在iPhone的safari下有bug
- discuz 系列产品 在ie9下注册成功后不跳转bug处理
- jquery的clone方法bug的修复select,textarea的值丢失
- JQuery在IE8兼容性视图模式下操作Select的Options的Bug