• CSS:z-index层级在IE中无效


    引用地址:http://apps.hi.baidu.com/share/detail/19853262

    在CSS中,只能通过代码改变层级,这个属性就是z-index,要让z-index起作用有个小小前提,就是元素的position属性要是relative,absolute或是fixed。

    1.第一种情况(z-index无论设置多高都不起作用情况):
    这种情况发生的条件有三个:
        1、父标签 position属性为relative;
        2、问题标签无position属性(不包括static);
        3、问题标签含有浮动(float)属性。
       
    eg:z-index层级不起作用,浮动会让z-index失效
    <div style="position:relative; z-index:9999;">
        <img style="float:left;" src="http://image.zhangxinxu.com/image/study/s/s256/mm2.jpg" />
    </div>   

    解决办法有三个(任一即可):
        1、position:relative改为position:absolute;
        2、浮动元素添加position属性(如relative,absolute等);
        3、去除浮动。
       
       
       
       
    2.第二种情况
    IE6下,层级的表现有时候不是看子标签的z-index多高,而要看整个DOM tree(节点树)的第一个relative属性的父标签的层级。

    eg:IE7与IE6有着同样的bug,原因很简单,虽然图片所在div当前的老爸层级很高(1000),但是由于老爸的老爸不顶用,可怜了9999如此强势的孩子没有出头之日啊!
    <div style="position:relative;">
        <div style="position:relative; z-index:1000;">
            <div style="position:absolute; z-index:9999;">
                <img src="http://image.zhangxinxu.com/image/study/s/s256/mm3.jpg" />
            </div>
        </div>
    </div>

    解决办法: 在第一个relative属性加上一个更高的层级(z-index:1)
    <div style="position:relative; z-index:1;">
        <div style="position:relative; z-index:1000;">
            <div style="position:absolute; z-index:9999;">
                 <img src="http://image.zhangxinxu.com/image/study/s/s256/mm3.jpg" />
            </div>
        </div>
    </div>

  • 相关阅读:
    MySQL 学习(六) InnoDB事务及MVCC
    MySQL学习(二) 存储过程
    一个二级缓存实例 (多级缓存)
    MySQL 学习(五) InnoDB架构
    验证POST接口是否可跨域(自用小工具,自用测试页面)
    用WindowsAppSDK(WASDK)优雅的开发上位机应用
    用PC windows作为Mac macos的扩展屏
    第一次使用webpack
    前端代码压缩工具closesure compiler
    JS代码操作CSS样式文件
  • 原文地址:https://www.cnblogs.com/wine/p/5047400.html
Copyright © 2020-2023  润新知