最近遇到一个弹出层在Chrome中重复的问题,观察发现是opacity引起的
以下是代码及现象
<!DOCTYPE html>
<html>

    <head>
        <meta charset="UTF-8">
        <title></title>
        <style>
            .fixing {
                position: absolute;
                top: 40px;
                bottom: 0;
                left: 0;
                right: 0;
                overflow: hidden;
                z-index: 9999;
                background: #ffffff;
                opacity: 0.2;
            }
            
            .fixing>div {
                width: 250px;
                height: 100px;
                position: absolute;
                top: 30%;
                left: 50%;
                margin-left: -125px;
                color: #fff;
                font-size: 18px;
                display: inline-block;
                vertical-align: middle;
                line-height: 100px;
                text-align: center;
                background: #000;
                border-radius: 10px;
            }
        </style>
    </head>

    <body>
        <div class="fixing" id="_loadingpageAuL41zL5pW">
            <div> <span>正在加载</span> <img src="/static/common/images/load.gif"></div>
        </div>
    </body>

</html>

 

 

图中只有第一个灰色弹出层是能定位到节点的,其他的都不能找到对应节点,好像是第一个的影子一样。

解决方案是非IE浏览器使用background:rgba(255,255,255,0.2)来代替原来的background和opacity,IE则用原来的方式background和filter。

虽然有了解决方案但是并不能解释清楚根本原因,有哪位大神可以给出官方解释呢?