靠谱的软件下载站
当前位置:  IEfans/ IE专区/ IE动态/ 高手解决IE中盒子模型滚动条有妙招

高手解决IE中盒子模型滚动条有妙招

IE动态 秩名 2018-07-04 02:07

Internet

类别:浏览器 大小:44MB 语言:简体中文

评分: 5
下载地址

其实不要看我们平时使用IE浏览器都是简简单单的,打开浏览器,输入所需网址,就完事了。可是当面对,稍微比较深奥的问题时,大家就搔头抓耳了。就比如关于浏览器盒子模型的滚动条的问题。下面,小编就此问题进行详细的讲述。

  先看图:

浏览器盒子模型的滚动条
浏览器盒子模型的滚动条

  那么我们来看容器高度:

  假如内容固定,表格也固定,那么你可能设置成固定高度,但是假如表格下还有内容,还正好取出来的数据不够表格的最大行数据(比如每页10行,结果一共才4行),那么会出现一大块空白,所以可能更多的情况下你还是设置的是动态高度,其实就是100%啦。

  既然是100%,那么为什么出现了竖滚条呢?首先,只有在IE下才出现这个滚动条,那么显然,肯定又是盒子模型对高宽的理解不同了。

  假如真实内容高度现在是500Px,因为横滚条(假定有12px)的出现,W3C可能认为高度就是512px了,那么事情就解决了,容器是512,内容是512。

  可是IE显然不这么计算,你现在内容高度是500px,那么我的100%算出来的就是500px,现在出现了横滚条怎么办?

  1,它必须在容器里出现(本例中就是外围的DIV);

  2,只要一出现,必须会把实际内容追加成512px;

  这样就出现了上面的结果,计算的高度和实际高度不符,于是滚动条就出现了。这时候来解决问题:

  开始认为,既然这是不应该出现的滚动条,那么就让它不显示不结了?于是给容器加style:overflow-y:hidden;

  结果一运行,不对,512px的内容被你强制改成了500px还不让滚动,必然有12px的内容无法显示,因为滚动条的级别比较高,所以不能显示的其实就是内容区的最后那12px,显然不能这么做

  最后没办法,只有先判断它是否IE,(IE8引擎已经有所改变,那就判断IE7吧),然后再插入一行(具体几行根据浏览器实际情况定,上述数字都是假的,为了描述方便),在这个时候,再让滚动条不出现,这样问题就解决了,

  在这种情况下,IE7事实上确实有部分内容无法显示,但无法显示的是你插入的无意义的空行。

  插入的代码你应该明白,是这种:

  《![if IE 7]》

  《p》 《/p》

  《![endif]》

  看效果:


浏览器盒子模型的滚动条

  好了,相信很多的朋友是看不懂的。只要是涉及到代码的问题,很多人就开始头晕了。大家不用担心,这种事情,还是让iE高手来解决。要是真的有兴趣,就认真学习一下吧!

标签: 容器高度 盒子模型滚动条

Copyright © 1998-2017 www.iefans.net All Rights Reserved 湘ICP备13012168号-17