浅谈CSS之浮动与定位

浅谈CSS之浮动与定位
一,浮动
1.传统网页布局的三种方式:
网页布局的本质——用CSS来摆放盒子。把盒子摆放到相应的位置。CSS提供了三种传统布局方式(简单说,就是盒子如何进行排列顺序)。
*普通流
*浮动
*定位
1.2 标准流特点
1.块级元素会独占一行,从上到下顺序排列。
常用元素:div,p,h1-h6,ul,ol,dl,form,table.
2.行内元素按照顺序,从左到右顺序排列,碰到父元素边缘则自动换行。
常用元素:span,a,i,em等。
1.3为什么需要浮动?
浮动可以改变元素标签默认的排列方式。
(网页布局第一准则:多个块级元素纵向排列找标准流,多个块级元素横向排列找浮动。)
1.4 什么是浮动
float属性用于创建浮动框,将其移动到一边,直到左边缘或右边缘触及包含块或另一个浮动框的边缘。
语法: 选择器 { float:属性值 ;}
属性值 描述
none 元素不浮动(默认值)
left 元素向左浮动
right 元素向右浮动
1.5 浮动的特性(重点)
加了浮动之后的元素会具有很多特性,主要讲述以下三点:
1.浮动元素会脱离标准流。
2.浮动的元素一行内显示并且元素顶部对齐。
3.浮动的元素会具有行内块元素的特性。
注:行内块元素特性:
设置了浮动的元素最重要的特性
1.脱离标准普通的控制(浮)移动到指定位置(动)(俗称脱标)。
2.浮动的盒子不在保留原先的位置。
3.若多个盒子设置了浮动,则它们会按照属性值一行内显示并且顶端对齐。
注意:浮动的元素是相互贴靠在一起的(不会有缝隙),如果父级宽度装不下这些浮动的盒子,多出的盒子会另起一行对齐。
3.浮动元素会具有行内块元素的特点
任何元素都可以浮动,不管原先是什么模式的元素,添加浮动之后具有行内块元素特性。
*如果块级盒子没有设置宽度,默认宽度和父级一样宽,但添加浮动之后,它的大小会根据内容来定。
*浮动的盒子中间没有缝隙,是紧挨着一起的(行内元素同理)。
1.6浮动元素经常和标准流搭配一起使用
为了约束浮动元素位置,我们网页布局一般采取的策略是:
先用标准流的父级元素排列上下位置,之后内部子元素采取浮动排列左右位置。符合第一准则《左右对齐以父盒子为准》
二,定位
1.为什么需要定位:
定位可以让盒子自由的在某个盒子内移动位置或者固定屏幕中某个位置,并且可以压住其他盒子。
2.定位的组成:
将盒子定在某一个位置,所以也是摆放盒子,按照定位的方式移动盒子。
定位=定位模式+边偏移。
定模用于指定一个元素在文档中的定位方式。边偏移则决定了该元素的最终位置。
1.定位模式
定位模式决定元素的定位方式,它通过CSS的position属性来设置,其值可以分为四个:
值 : 语义:
static 静态定位
relative 相对定位
absolute 绝对定位
fixed 固定定位
2.边偏移:
有 :top bottom left right 4个属性。
eg: top:80px 顶端偏移量,定义元素相对于父元素上边线的距离。

1.3 静态定位:
static(了解):是元素默认定位方式,无定位的意思。
语法:{position: static ;} *按照标准流特性摆放位置,没有边偏移。布局很少用到。
1.4 相对定位(relative)重要
相对定位是元素在移动位置的时候,是相对于它原来的位置来说的。(以自我为中心)
语法:选择器 { position: relative ;}
相对定位的特点:(务必牢记)
1.它是相对于自己原来的位置来移动的(换句话说,移动位置的时候参照点是自己原来的位置)。
2.原来在标准流的位置继续占有,后面的盒子任然以标准流的方式对待它。(不脱标,继续保留原来的位置)
1.5 绝对定位(absolute)重点
语法:选择器{ position:absolute ;}
绝对定位特点:
1.如果没有祖先元素或者祖先元素没有定位,则以浏览器为准进行定位(Document文档)
2.如果祖先元素有定位(相对,绝对,固定定位),则以最近一级的有定位的祖先元素为参考点移动位置。
3.绝对定位不再占有原来的位置(脱标)。
1.6 子绝父相的由来
meaning:子级使用绝对定位,父级则需要相对定位。
1.子级相对定位,不会占有位置,可以放到父盒子里面任何一个地方,不会影响其他的兄弟盒子。
2.父盒子需要加定位限制子盒子在父盒子内显示。
3.父盒子布局时,需要占有位置,因此父亲只能是相对定位。
1.7 固定定位(fixed)
固定定位是元素固定于浏览器可视区的位置,主要使用场景:可以在浏览器页面滚动时元素的位置不会改变。
语法:{ position:fixed;}
特点:
1.以浏览器的可是窗口为参照点移动元素,跟父元素没有任何关系,不随滚动条滚动而滚动。
2.固定定位不在占有原先的位置。
固定定位也是脱标的,其实固定定位也可以看做是特殊的绝对定位。
小技巧:固定版心右侧
1.让固定定位的盒子left:50%,走到浏览器可视区的(也可以看做版心)的一半位置。
2.让固定定位的盒子margin-left:版心宽度的一半距离,多走版心区域的一般位置就可以让固定定位的盒子贴着版心右侧对齐了。
1.10 定位叠放次序(z-index)
在使用定位布局时,可能会出现盒子重叠的情况,此时,可以使用z-index来控制盒子的前后次序(z轴)。
语法:选择器 { z-index :auto(数值越大越靠上) ;}
如果属性值相同,则按照书写顺序,后来居上。
数字后面不加单位,只有定位的盒子才有z-index属性。
数值可以是正整数,复数,或者时零,默认是auto。
1.11定位的拓展
1.绝对定位的盒子居中
1.left走50% 父容器宽度的一半。
2.margin 负值 往左走自己盒子宽度的一半。

2.定位的特殊性
绝对定位和固定定位也和浮动类似。
1.行内元素添加绝对定位或者固定定位,可以直接设置高度和宽度。
2.块级元素添加绝对或者固定定位,如果不给高度和宽度,默认大小是内容大小。
3.脱标的盒子不会触发外边距塌陷。
浮动元素,绝对定位(固定定位)元素都不会触发外边距合并的问题。
4.绝对定位(固定定位)会完全压住盒子。

浮动元素不同,只会压住它下面标准流的盒子,但是不会压住下面标准流盒子里面的文字(图片)
但绝对定位(固定定位)会压住下面标准流所有的内容。
注:浮动之所以不会压住文字,因为浮动产生的目的最初是为了做文字环绕效果。文字会围绕浮动元素。

上述仅代表个人观点,,,请大佬勿喷!!!!!

你可能感兴趣的:(css3)