当我在大页面上遇到问题时,我正在处理带有透明背景叠加层的JavaScript对话框。IE高度> 4096px显示透明度错误?
如果页面很大,透明覆盖图将是纯色(即不再透明)。我做了一些测试,发现这只发生在叠加高于4096像素(嗯,可疑,这是2^12)。
任何人都可以验证此问题吗?你有没有看到解决方法?
这里是我的测试代码(我使用的原型):
<style>
.overlayA {
position:absolute;
z-index:10;
width:100%;
height:4095px;
top:0px;
left:0px;
zoom: 1;
background-color:#000;
filter:alpha(opacity=10);
-moz-opacity:0.1;
opacity:0.1;
}
.overlayB {
position:absolute;
z-index:10;
width:100%;
height:4097px;
top:0px;
left:0px;
zoom: 1;
background-color:#000;
filter:alpha(opacity=10);
-moz-opacity:0.1;
opacity:0.1;
}
</style>
<div style="width:550px;height:5000px;border:1px solid #808080">
<a href="javascript:// show overlay A" onclick="Element.show('overlayA')">Display A = 4096h</a>
<br /><a href="javascript:// show overlay B" onclick="Element.show('overlayB')">Display B = 4097h</a>
</div>
<div id="overlayA" onclick="Element.hide(this)" class="overlayA" style="display:none"></div>
<div id="overlayB" onclick="Element.hide(this)" class="overlayB" style="display:none"></div>
任何工作解决方案对于IE? – muneebShabbir 2012-05-22 05:53:34
您需要确定屏幕何时大于4096,并使用多个叠加层,其中一个位于前一个之下。 – 2012-05-22 13:21:18