2011-06-28 76 views
0

我有一个div,它的高度是由javascript控制的,它应该会在窗口调整大小时改变div的大小。放大窗口时它现在工作正常,但缩小窗口时不起作用。可能是什么原因?我有下面的代码当窗口缩小时,IE div不会相应缩小

<script type="text/javascript"> 
     function window_resize() { 
      var height = 0; 
      var body = window.document.body; 
      if (window.innerHeight) { 
       height = window.innerHeight; 
      } else if (body.parentElement.clientHeight) { 
       height = body.parentElement.clientHeight; 
      } else if (body && body.clientHeight) { 
       height = body.clientHeight; 
      } 

      var element = document.getElementById('test'); 
      element.style.height = height*80/100 + 'px'; 
     } 

     Sys.Application.add_init(function (sender, args) { 
      $addHandler(window, 'resize', window_resize); 
      $addHandler(window, 'onload', window_resize); 
      document.body.onresize = window_resize; 
      document.body.onload = window_resize; 
     }); 

    </script> 

    <div id="test" style="width:1000px;padding:0px;margin:0px;"> 
     <spc:Explorer ID="explorer" runat="server"></spc:Explorer> 
    </div> 
+0

你在这里使用JavaScript库吗? – kinakuta

+0

是的,div中有一个控件(id为'explorer')。本质上来说,控制来自extjs。 – tom

回答

0

我猜测当窗口变小时div太小。可能的原因是缩小窗口大小会使滚动条出现(即使它们未显示),因此窗口大小的计算在滚动条内。

一种解决方法是将body.style.display = 'none'应用于身体,获得窗口的大小,然后做body.style.display = ''

+0

刚刚尝试过,不起作用。 :-( – tom

相关问题