您现在的位置是:网站首页> 编程资料编程资料
IE绝对定位元素神秘消失或被遮挡的解决方法_CSS教程_CSS_网页制作_
2021-09-08
610人已围观
简介 在进行网页布局的时候,经常会根据需要设置相对,绝对以及浮动定位;
发现了一个奇妙的现象:
查了相关资料,高人有这样的解释:
1.当绝对定位层的邻近浮动层的宽度不等于父层宽度时,以及没有清除浮动时,IE6/7,FF中显示一致;
2.当绝对定位层的邻近浮动层的宽度不等于父层宽度时,有清除浮动时,IE6/7不显示绝对定位层,FF显示;
3.当绝对定位层的邻近浮动层的宽度等于父层宽度时,以及没有清除浮动时,IE6不显示绝对定位层,IE7/FF显示;
4.当绝对定位层的邻近浮动层的宽度等于父层宽度时,有清除浮动时,IE6/7不显示绝对定位层,FF显示;
要解决这个BUG的方法也很简单,让绝对定位层不挨着浮动层放置就好了,还有个更简单的方法,在绝对定位元素和其他元素之间加一个空白的div。
再来看看绝对定位元素神秘消失被遮挡的现象
先了解一下所涉及到的几个定位特性:
1. 相对定位元素默认的z-index的数值是0。
2. 当两个相对定位同时出现时,代码靠后的z-index优先。
3. 子级遵循父级设定的z-index;如果子级设定了绝对定位、z-index,可以冲破父级显示
看下面的代码:
代码解释:上面是三个相邻的相对定位的层,在第一个层里加了个相对其绝对定位的层,按照理论,这个绝对定位的元素是在三个相对定位元素之上的,但是,实际却没有显示。尝试设置z-index值也没有效。
网上解决这个bug的办法一般用hack使B为负值,来降低 B 在IE下级别
但是这种方法在z-index为负值时,产生了新的ie bug
按照定位的特性,ie的这个bug是可以回避的
从表面上看 下面的层 遮住了上面的绝对定位层,实际上是下面的 层遮住了绝对定位的的父级层,只要将 该父级层 的z-index设定大于后面的层即可
查了相关资料,高人有这样的解释:
1.当绝对定位层的邻近浮动层的宽度不等于父层宽度时,以及没有清除浮动时,IE6/7,FF中显示一致;
2.当绝对定位层的邻近浮动层的宽度不等于父层宽度时,有清除浮动时,IE6/7不显示绝对定位层,FF显示;
3.当绝对定位层的邻近浮动层的宽度等于父层宽度时,以及没有清除浮动时,IE6不显示绝对定位层,IE7/FF显示;
4.当绝对定位层的邻近浮动层的宽度等于父层宽度时,有清除浮动时,IE6/7不显示绝对定位层,FF显示;
要解决这个BUG的方法也很简单,让绝对定位层不挨着浮动层放置就好了,还有个更简单的方法,在绝对定位元素和其他元素之间加一个空白的div。
再来看看绝对定位元素神秘消失被遮挡的现象
先了解一下所涉及到的几个定位特性:
1. 相对定位元素默认的z-index的数值是0。
2. 当两个相对定位同时出现时,代码靠后的z-index优先。
3. 子级遵循父级设定的z-index;如果子级设定了绝对定位、z-index,可以冲破父级显示
看下面的代码:
复制代码
代码如下:代码解释:上面是三个相邻的相对定位的层,在第一个层里加了个相对其绝对定位的层,按照理论,这个绝对定位的元素是在三个相对定位元素之上的,但是,实际却没有显示。尝试设置z-index值也没有效。
网上解决这个bug的办法一般用hack使B为负值,来降低 B 在IE下级别
但是这种方法在z-index为负值时,产生了新的ie bug
按照定位的特性,ie的这个bug是可以回避的
从表面上看 下面的层 遮住了上面的绝对定位层,实际上是下面的 层遮住了绝对定位的的父级层,只要将 该父级层 的z-index设定大于后面的层即可
相关内容
- css 解决浏览器兼容问题_浏览器兼容教程_CSS_网页制作_
- CSS网页布局中的最小高度问题的解决方法_CSS教程_CSS_网页制作_
- Css 模块化编码技巧_CSS教程_CSS_网页制作_
- CSS层叠与继承的使用深入剖析_CSS教程_CSS_网页制作_
- CSS对浏览器的兼容性技巧总结 _浏览器兼容教程_CSS_网页制作_
- 纯CSS+Div 的标签实现代码_CSS教程_CSS_网页制作_
- 深入浅出CSS3 background-clip,background-origin和border-image教程 _css3_CSS_网页制作_
- css 标题一行图片 两行文字的排列方法以及相关问题处理 _CSS教程_CSS_网页制作_
- CSS Sprite打造的个性化导航菜单代码_CSS教程_CSS_网页制作_
- IE6、IE7、IE8浏览器下的CSS、JS兼容性对比_浏览器兼容教程_CSS_网页制作_