您的位置:首页 > 其它

ie6 select无法被div遮盖的bug解决

2010-11-05 11:12 471 查看
使用div制作蒙版或模拟弹出窗口,但在IE6下,当div下方有下拉列表框select元素的时候,下拉列表框会划破div显示在div之上,不论z-index设为何值均会出现此问题,可能由于下拉列表控件的弹出式下拉列表的原因导致Z轴高度失控。但是IE6有一个神奇的逻辑,div 无法覆盖select,但是iframe 可以覆盖select,而div可以覆盖iframe,所以解决办法就是用Z轴高度更高的Iframe元素,包裹或覆盖住下拉列表框控件,使其回到正常的Z轴高度上来!

html如下:

Html代码



<div id="acontainnerbox" class="aboxinitcss">

这里是很多代码,www.k686.com

<iframe class="ifhideselect" frameborder="0"></iframe>

</div>

<div id="acontainnerbox" class="aboxinitcss">
这里是很多代码,www.k686.com
<iframe class="ifhideselect" frameborder="0"></iframe>
</div>


css代码如下:

Html代码



.aboxinitcss{

position:absolute;

margin-top:0px;

margin-left:0px;

display:none;

background:#FFF;

border:solid #CCC 1px;

padding:30px;

z-index:9999;

width:620px;overflow:hidden;

}

.ifhideselect{

z-index:-1;

width:680px;

height:255px;

position:absolute;

border:0;

left:0;

top:0;

}

.aboxinitcss{
position:absolute;
margin-top:0px;
margin-left:0px;
display:none;
background:#FFF;
border:solid #CCC 1px;
padding:30px;
z-index:9999;
width:620px;overflow:hidden;
}
.ifhideselect{
z-index:-1;
width:680px;
height:255px;
position:absolute;
border:0;
left:0;
top:0;
}


即可解决这个bug.
iframe的z-index一定要设置为负数,不然遮盖不住.
参考1:http://www.jinweijie.com/javascript/fix-ie-6-select-overlap-bug-problem/
参考2:/article/5731825.html
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: