1、破坏性和包裹性

position:absolute与float:left,两者有两大共性:包裹性,破坏性。

包裹性
包裹性换种说法就是让元素inline-block化,例如一个div标签默认宽度是100%显示的,但是一旦被absolute属性缠上,则100%默认宽度就会变成自适应内部元素的宽度。

<div class="fz">
<div class="bg-red">
<p>无absolute</p>
</div>
<div class="abs bg-grey">
<p>absolute后</p>
</div>
</div>

float也是典型的inline-block化元素。

破坏性:

absolute比float的破坏性更强:

浮动的破坏性在于切断line box链,致使高度塌陷,但其占据的实体位置还是在的。

而absolute不仅让高度塌陷,宽度也塌陷。

注意:对于普通页面的布局,不到万不得已不要使用absolute。

absolute尽量不要身陷林立的DOM中,尤其是用来做普通的布局。

2、absolute布局的替代实现

详见《absolute布局的替代实现》

body标签是absolute元素自由的天空,如absolute没有relative属性的限制,其会一直飞到天空的边缘(浏览器窗口)。

把推荐将隐藏的绝对定位元素放在body标签内部,且最底部加载,以提高页面的呈现速度,甚至根本就不加载。

将默认隐藏的绝对定位元素被relative限制在很深的DOM节点中,弊处相当多:

①首先增加了DOM的复杂度,不利于维护;越深的DOM元素,造成了回 流越强;

②因为父标签需要relative限制,增加了CSS代码的消耗量;

③隐藏元素头部加载,延迟了页面的呈现速度;每个下拉几乎都要重新定位,其重用性 受限。

3、absolute之元素隐藏

详见《css隐藏元素的几种方法》

4、绝对定位等高布局

5、absolute属性与IE6/IE7之间的误会

4、相对定位的最小化影响原则

追加:1、static:如果没有指定position的值,默认为static。源代码中各个标签的先后位置,就是它们所对应的对象的呈现次序

2、relative:保持对象所在文档流中的位置,跟static不同的是可以通过top,left,right,bottom改变自己的位置,这四个属性的取值是相对于文档流的前一个对象,原来呈现的页面仍然会我行我素(即通过设置top等属性,不会影响原来文档流的布局。)

3、absolute:将当前对象拖出文档流独立显示。

4、z-index:元素应用了非static的position属性后,就会有一个隐晦的层级,会居于普通元素之上。 无需额外设置z-index。

relative设置了z-index。一般情况是为改变它的子元素absolute的层级。因为absolute是“拼爹”,对relative本身无影响。

不同relative里面的absolute的层级关系是根据它的父relative层级有关,即“拼爹”,但ie6、7例外,参考以下②。

ie6问题:

①float+relative在面对absolute的时候,无论relative的层级多高都沦陷

.blank{ width: 100%; height: 600px; background-color: #000000; opacity: 0.4; filter:alpha(opacity=40); left:; top:;}
<div class="blank abs zx1"></div>
<div class="rel zx9">
<img class="l" src=" images/yyy.jpg" width="150" height="150">
</div>

正常效果是:

img层位于blank之上。但在ie6中,float的img+relative。无论relative的层级有多高,都沦陷,位于absolute之下了。

解决办法:1、position:relative改为position:absolute;2、去除浮动;3、浮动元素添加position属性(如relative,absolute等)

②正常浏览器的z-index都是“拼爹”,但是ie6、7是拼该absolute的第一个relative

<div class="blank abs zx2"></div>
<div class="rel zx1">
<div class="rel zx8">
<div class="abs zx1">
<img src="data:images/yyy.jpg" width="150" height="150">
</div>
</div>
</div>

正常浏览器img位于blank之上,因为blank的层级是zx2,而img所在div(即便它本身才zx1,但它)的爹(rel)的层级是zx8。

ie6,7浏览器不认爹,认它爹的爹rel层级为zx1,小于blank的层级。固效果为:

解决办法:只需改变img所在层的第一个(或者说最老那个爹)relative的层级。

bug:

以上代码在firefox运行,图片仍被遮挡。个人理解是如果abs图片的祖先rel设置了z-index的值,则认祖先的,如果没有设置则认父z-index的。

但是在ie6、7里面不管祖先z-index有没设置都认祖先的。

CSS相对|绝对(relative/absolute)定位的更多相关文章

  1. CSS 相对|绝对(relative/absolute)定位系列(一)

    一.有话要说 以前写内容基本上都是:眼睛一亮——哟呵,这个不错,写!然后去古人所说的茅房里蹲会儿,就有写作的思路了.但是,构思相对/绝对(relative/absolute)定位系列却有好些时日,考虑 ...

  2. CSS 相对/绝对(relative/absolute)定位系列(四)——张鑫旭

    前三篇(1, 2, 3)都是介绍的absolute属性,终于,轮到本文讲讲relative相对定位. 一.relative属性的形象化思维 relative是个看上去低调,有些特殊才能,气场强大,有着 ...

  3. CSS 浅析position:relative/absolute定位方式

    ## 一.position:relative 相对定位 ## 分两种情况分析: · 无 position: relative: · 有 position: relative. 代码如下图: 显示效果如 ...

  4. CSS:static/relative/absolute

    static - default and this is the FLOW. ------------------------------------------------------------- ...

  5. CSS 相对/绝对(relative/absolute)定位与jQuery的控制显示隐藏

    曾经写显示隐藏老是用jq方法控制: dom.show(); dom.hide(); 事实上这样还是有非常多缺陷的. 这是html结构: <div class="holi"&g ...

  6. (转)Position定位:relative | absolute

    原文:http://hi.baidu.com/zxc0420/item/9ada5110845ba1e89c778a08 Position定位:relative | absolute 定位一直是WEB ...

  7. css深入理解relative

    第一讲     relative和absolute相煎关系 同源性 .position:relative .position:absolute 限制作用 1.限制left/top/right/bott ...

  8. css的定位,relative/absolute/fixed的用法

    其实position的值有四个,static/relative/absolute/fixed,而static是默认值,不算具有有定位属性,这里就不讲了. 定位其实就是跟元素设置定位属性,然后设置其对位 ...

  9. CSS+DIV定位分析(relative,absolute,static,fixed)

    在用CSS+DIV进行布局的时候,一直对position的四个属性值relative,absolute,static,fixed分的不是很清楚,以致经常会出现让人很郁闷的结果.今天研究了一下,总算有所 ...

  10. CSS之定位,relative/absolute/fixed的用法

    其实position的值有四个,static/relative/absolute/fixed,而static是默认值,不算具有有定位属性,这里就不讲了. 定位其实就是跟元素设置定位属性,然后设置其对位 ...

随机推荐

  1. mysql数据库查看各实例磁盘占用情况

    1.总体查看: use information_schema; select TABLE_SCHEMA, concat(truncate(sum(data_length)/1024/1024,2),' ...

  2. 2017.2.7 开涛shiro教程-第六章-Realm及相关对象(三)

    原博客地址:http://jinnianshilongnian.iteye.com/blog/2018398 根据下载的pdf学习. 第六章 Realm及相关对象(三) 1.准备3个Realm MyR ...

  3. poj 1328 Radar Installation 【贪心】【区间选点问题】

    Radar Installation Time Limit: 1000MS   Memory Limit: 10000K Total Submissions: 54798   Accepted: 12 ...

  4. SQLServer待优化语句查询

    SELECT top 100 (total_elapsed_time / execution_count)/1000 N'平均时间ms' ,total_elapsed_time/1000 N'总花费时 ...

  5. Java设计模式(九)责任链模式 命令模式

    (十七)责任链模式 责任链模式的目的是通过给予多个对象处理请求的机会,已解除请求发送者与接受者之间的耦合关系.面对对象的开发力求对象之前保持松散耦合,确保对象各自的责任最小化.这种设计能够使得系统更加 ...

  6. 度度熊有一张网格纸,但是纸上有一些点过的点,每个点都在网格点上,若把网格看成一个坐标轴平行于网格线的坐标系的话,每个点可以用一对整数x,y来表示。度度熊必须沿着网格线画一个正方形,使所有点在正方形的内部或者边界。然后把这个正方形剪下来。问剪掉正方形的最小面积是多少。

    // ConsoleApplication10.cpp : 定义控制台应用程序的入口点. // #include "stdafx.h" #include <iostream& ...

  7. 认识 service worker

    离线缓存可以提升用户体验,可以节省网络资源,但是,浏览器对资源缓存和自定义网络请求的控制一直不够完善,service worker 的出现就是为了解决这些问题 它可以解决目前离线应用的问题,同时也可以 ...

  8. XP,32/64位Win7,32/64位Win10系统【电脑城版】

    本系统是10月最新完整版本的Windows10 安装版镜像,Win10正式版,更新了重要补丁,提升应用加载速度,微软和百度今天宣布达成合作,百度成为Win10 Edge浏览器中国默认主页和搜索引擎,系 ...

  9. ASP.NET动态网站制作(8)-- JS(3)

    前言:JS的第三节课,这节课主要讲函数.对象及方法. 内容: 1.九九乘法表例子: HTML代码: <!DOCTYPE html> <html xmlns="http:// ...

  10. CAS实现单点登录理解

    CAS 是 Yale 大学发起的一个企业级的.开源的项目,旨在为 Web 应用系统提供一种可靠的单点登录解决方法(属于 Web SSO ),CAS 开始于 2001 年, 并在 2004 年 12 月 ...