CSS 定位和浮动
CSS 定位和浮动提供了一些特性,使用这些属性,你可以建立栏布局,的重叠布局的一部分,并有一些。也可多年来完成通常需要使用的多个表格能力完成的任务。
定位的基本思路是非常easy。对于其正常位置应该出现的位置,或者相对于父元素、还有一个元素甚至浏览器窗体本身的位置。显然。这个功能非常强大,也非常让人惊讶。要知道,用户代理对 CSS2 中定位的支持远胜于对其他方面的支持,对此不应感到奇怪。
一切皆为框
div、h1 或 p 元素经常被称为块级元素。这意味着这些元素显示为一块内容,即“块框”。与之相反,span 和 strong 等元素称为“行内元素”,这是由于它们的内容显示在行中,即“行内框”。
您能够使用 display 属性改变生成的框的类型。这意味着。通过将 display 属性设置为 block,能够让行内元素(比方 <a> 元素)表现得像块级元素一样。还能够通过把 display 设置为 none,让生成的元素根本没有框。这种话,该框及其全部内容就不再显示,不占用文档中的空间。
可是在一种情况下。即使没有进行显式定义,也会创建块级元素。这样的情况发生在把一些文本加入到一个块级元素(比方 div)的开头。即使没有把这些文本定义为段落。它也会被当作段落对待。
CSS 定位机制
CSS 有三种主要的定位机制:普通流、浮动和绝对定位。
除非专门指定,否则全部框都在普通流中定位。也就是说。普通流中的元素的位置由元素在 (X)HTML 中的位置决定。
块级框从上到下一个接一个地排列。框之间的垂直距离是由框的垂直外边距计算出来。
行内框在一行中水平布置。能够使用水平内边距、边框和外边距调整它们的间距。
可是,垂直内边距、边框和外边距不影响行内框的高度。由一行形成的水平框称为行框(Line Box),行框的高度总是足以容纳它包括的全部行内框。只是,设置行高能够添加这个框的高度。
以上文字都来自W3CSCHOOL的描写叙述,非常多人看了之后还只不过知道所以然,不知其所以然。
以下我用实际的样例演示给大家看。
这里我们仅仅对经常使用的默认值static以及相对定位用到的relative和绝对定位absolute做一个具体的介绍
在我们定义的不论什么一个块级元素中,假设没有给其定义positon样式属性,那么它将都是默认static,块级框从上到下一个接一个地排列,框之间的垂直距离是由框的垂直外边距计算出来。假设是行内元素那么将横向排列直到占满当前行。
很多其它的时候我们在div+css布局中是使用相对、绝对定位。而且绝大部分时候是混合使用。
同一时候使用position:absolute
<div style="position:absolute;left:50px;top:50px;border:1px solid red;100px;height:100px;"></div> <div style="position:absolute;left:100px;top:100px;border:1px solid #000;100px;height:100px;"></div>
能够看出它们都是相对于浏览器定位的。互不影响。
同一时候使用position:relative
<div style="position:relative;left:50px;top:50px;border:1px solid red;100px;height:100px;"></div> <div style="position:relative;left:100px;top:100px;border:1px solid #000;100px;height:100px;"></div>
能够看出第一个div还是相对于浏览器定位,第二个div的left还是100px。而top已经变为200px。这就是由于相对定位的原因由于上方已经有一个元素,第二个div的top以第一个div在占用的height为准。
先使用position:absolute,后使用position:relative
<div style="position:absolute;left:50px;top:50px;border:1px solid red;100px;height:100px;"></div> <div style="position:relative;left:100px;top:100px;border:1px solid #000;100px;height:100px;"></div>
能够看出第一个div还是以浏览器为绝对定位,第二个div尽管为relative但并没有受第一个div的影响,还是以浏览器定位。
先使用position:relative,后使用position:absolute
<div style="position:relative;left:50px;top:50px;border:1px solid red;100px;height:100px;"></div> <div style="position:absolute;left:100px;top:100px;border:1px solid #000;100px;height:100px;"></div>
这和上面一个一模一样。我们应该能够总结出一点,假设有且仅仅使用了一个相对定位,无论使用了多少个绝对定位,那个使用了相对定位的元素都不会受绝对定位元素的影响
先使用默认值static,后使用relative
<div style="border:1px solid red;100px;height:100px;"></div> <div style="position:relative;left:100px;top:100px;border:1px solid #000;100px;height:100px;"></div>
第二个div的top值在这里已经变为200px
先使用默认值static,后使用absolute
<div style="border:1px solid red;100px;height:100px;"></div> <div style="position:absolute;left:100px;top:100px;border:1px solid #000;100px;height:100px;"></div>
第二个div还是无视不论什么其他定位的元素。始终以浏览器为准
ps:假设我们不想以浏览器为绝对定位点,而是以某个我们自定义的块级元素为起始点呢,这仅仅要把这个元素的设为一个相对定位。然后它的子元素使用不论什么定位都将以它为准,而不再是浏览器。
比方:
这里全部的草绿色大框都设置了position:relative,里面的小盒子给它的所有发言为准的定位。
版权声明:本文博主原创文章。博客,未经同意不得转载。