一、CSS 定位和浮动
 
它们代替了多年来的表格布局。
 
定位的思想很简单,相对于正常位置、相对于父元素、另一个元素甚至是浏览器窗口的位置。
 
浮动在 CSS1 中被首次提出。浮动不完全是定位,当然也不是正常的流布局。
 

 
二、一切都是框
 
display 属性设置元素是什么框类型。其属性为 block、inline、none 时,分别表示块级元素、行内元素和不显示(也不占用文档的空间)。
 

 
三、定位机制
 
有三种基本的:普通流、绝对定位和浮动。
 
在下面的小节里,会给你详细讲解相对定位、绝对定位和浮动。
 

 
四、定位(position)属性的四个值
 
static、relative、absolute 和 fixed。
 
static(默认):正常显示的位置
 
relative:相对于正常显示位置,偏移后的位置。发生偏移后,原本所占的空间仍然保留。
 
absolute:相对于包含块定位,包含块可能是文档中的另一个元素或者是初始包含块。元素原先在正常文档流里的所占空间不再保留,就好像元素原来就不存在一样。
 
fixed:表现类似 absolute,不过它的包含块是浏览器的窗口。
 
其实,相对定位实际上被看作是普通流定位中的一部分,因为元素的位置相对于它在普通流中的位置。
 

 
五、相对定位 relative
 
这是一个非常容易掌握的概念。一个元素被设置为相对定位,那就是相对于它的起点(正常的位置)垂直或者水平移动一段距离。
 
举个例子:如果一个元素,要相对于正常位置,往下 20 像素,往右 30 像素,那么它的 CSS 代码应该这样↓
 
#box_relative {
position: relative;
left: 30px;
top: 20px;
}
 
我们看页面最终效果的话,会更加直观:
 
 
注意,使用相对定位进行移动,原来元素所占据的空间仍然保留,不仅如此,它还会覆盖其它的框。
 

 
六、绝对定位 absolute
 
绝对定位的元素是一个块级框,而不论它在正常流中是何种类型的框。
 
与相对定位不同的是,绝对定位会从文档流里完全删除,所以不占据空间,并相对于其包含块定位。在普通流里布局的元素,就当作绝对定位元素不存在一样:
 
#box_relative {
position: absolute;
left: 30px;
top: 20px;
}

 
这里的包含块是指最近的被定位的(positioned)元素。被定位的元素是指 position 的取值除 static 之外的元素。
 
如果绝对定位的元素往上一级、往上上一级……到文档的 body 元素了,如果还没找到包含块,那么它的包含块就是 body,它最终相对于 body 元素定位!
 

 
七、绝对定位 fixed 
 
与 absolute 类似,不过它是相对于视窗(浏览器窗口)定位的。通常一张页面的顶部导航栏就是用 fixed 定位的。
 
 
但,移动浏览器对 fixed 的支持很差。不过,这里有解决方案。
 

 
八、浮动
 
关于浮动,并不难,但有一大堆要说的,放在以后吧。
 
(完)

CSS 定位的更多相关文章

  1. css定位

    文档流 所谓的文档流,指的是元素排版布局过程中,元素会自动从左往右,从上往下的流式排列.并最终窗体自上而下分成一行行, 并在每行中按从左至右的顺序排放元素.脱离文档流即是元素打乱了这个排列,或是从排版 ...

  2. 常用的CSS定位,XPath定位和JPath定位

    CSS定位 举例 描述 div#menu id为menu的div元素 div.action-btn.ok-btn class为action-btn和ok-btn的div元素 table#emailLi ...

  3. div+css定位position详解

    div+css定位position详解 1.div+css中的定位position 最主要的两个属性:属性 absolute(绝对定位) relative(相对定位),有他们才造就了div+css布局 ...

  4. Selenium自动化中DOM,XPATH,CSS定位Web页面对象的优劣性分析

    加速IE浏览器自动化执行效率:Selenium自动化中DOM,XPATH,CSS定位Web页面对象的优劣性分析 1.技术背景       在Web应用中,用户通过键盘在输入框中输入值和鼠标点击按钮,链 ...

  5. CSS定位小技巧

    CSS定位Static 默认定位Relative 相对定位:left 和topposition: relative;/*相对定位*/ left:40px;/*在原来的位置向右移动*/ top:100p ...

  6. (七)CSS定位(Positioning)

    CSS定位属性允许对元素进行定位. 一切皆为框: div.h1或p元素常被称为块级元素,而span和strong等元素成为行内元素,但是可是使用 display 属性改变框的类型,将display设置 ...

  7. CSS定位(CSS定位概述、相对定位、绝对定位、浮动)

    CSS 定位属性 CSS 定位属性允许你对元素进行定位. 属性 描述 position 把元素放置到一个静态的.相对的.绝对的.或固定的位置中. top 定义了一个定位元素的上外边距边界与其包含块上边 ...

  8. CSS定位(postion)和移动(float)

    5.定位和移动:Positioning(定位)CSS定位属性允许你为一个元素定位.它也可以将一个元素放在另一个元素后面,并指定一个元素的内容太大时,应该发生什么. 元素可以使用的顶部,底部,左侧和右侧 ...

  9. CSS定位属性Position详解

    CSS中最常用的布局类属性,一个是Float(CSS浮动属性Float详解),另一个就是CSS定位属性Position. 1. position:static 所有元素的默认定位都是:position ...

随机推荐

  1. 第一个django

    4.创建第一个Django工程 Django环境算是配置完成了,你可以到命令提示符下创建第一个Django应用,进入某个目录,执行django-admin.py startproject myproj ...

  2. 中介者模式(Mediator)

    GOF:用一个中介对象来封装一系列的对象交互.中介者使对象不需要显式地相互引用,从而使其耦合松散,而且可以独立地改变它们之间的交互. 类图:

  3. Kinect 图像帧的格式

    一.ColorImageFormat:彩色图像帧的格式 RawYuvResolution640x480Fps15 原始YUV格式,分辨率是640x480,每秒15帧: RgbResolution128 ...

  4. [转]如何将SQL Server表驻留内存和检测

    注意这个功能在SQL2005后已经废弃,因为SQL2005会自动管理哪些表常驻内存. 将SQL Server数据表驻留内存是SQL Server提供的一项功能,在一般小型系统的开发过程中估计很少会涉及 ...

  5. 3D touch的 使用心得

    一.设置图标touch 快捷进入 1.静态标签 静态标签是我们在项目的配置plist文件中配置的标签,在用户安装程序后就可以使用,并且排序会在动态标签的前面. 我们先来看静态标签的配置: 首先,在in ...

  6. node crypto md5加密,并解决中文不相同的问题

    在用crypto模块时碰到了加密中文不相同的问题,多谢群里面@蚂蚁指定 1:解决中文不同的问题 function md5Pay(str) { str = (new Buffer(str)).toStr ...

  7. DOM9大节点

    ELEMENT_NODE 1 元素节点 常用 ATTRIBUTE_NODE 2 属性节点 常用 TEXT_NODE 3 文本节点 常用 CDATA_SECTION_NODE 4 CDATA区段   E ...

  8. Unity3D 系统宏

    Platform Defines The platform defines that Unity supports for your scripts are:     Property: Functi ...

  9. Python2.7的安装

    >登录python官网下载python2.7的相关版本 python官网链接 >根据平台选择相应的版本 >下载完毕后点击安装即可 >配置环境变量 >安装成功

  10. IOS 谓词

    // 谓词 Person *person = [[Person alloc]init]; person.name = @"zhang san"; person.age = 20; ...