万恶的IE之动态添加DOM节点触发window.resize事件

今天浪费了快一下午的时间在这上面了......

因为页面很多UI是绝对定位的,所以当窗口大小改变的时候会使原先的布局混乱,只好在每次window.resize的时候重新布局...

然后页面有几个事件是动态地增加DOM元素的,比如点击某个层会在底下列出该层详细内容,这样在FF和chrome下没出现问题,但是在IE6-8下每次都重布局了.

比如我拖动一个层,在拖动过程中层的内容又显示在最底下了,当我放开层的时候这个层就跳回拖动前的位置了...

起先我还没看出来是重布局了...然后演示了N久,挣扎了N久,终于觉得可能是由于动态增加DOM节点导致触发window.resize而使页面重布局了...

最后我不由地在心里喊了句"Thank godness....",还好改变窗口的高度对页面布局没有影响,不然真要麻烦死了...

 
  
1 bindResizeWindow: function (){
2 var obj = this ;
3 $(window).resize( function (){
4 var newWidth = $(window).width();
5 if(newWidth == obj.windowWidth){return ;}
6 obj.initUI();
7 obj.createUI();
8 obj.windowWidth = newWidth;
9 });
10 },
只要在绑定方法中判只有宽度改变时才触发重布局事件就行了...

 

顺便赞美一下OO,让JS编程也如此清晰,方便...

转载于:https://www.cnblogs.com/adaikiss/archive/2010/07/26/1785404.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值