1. 盒子模型(Box Model)
所谓盒子模型:
- 就是把HTML页面中的布局元素看作是一个矩形的盒子,也就是一个盛装内容的容器。
- 盒子模型有元素的内容、边框(border)、内边距(padding)、和外边距(margin)组成。
- 盒子外面的文字和图片等元素是 内容区域
- 盒子的厚度 咱们成为 盒子的边框
- 盒子内容与边框的间隔是内边距(相似单元格的 cellpadding)
- 盒子与盒子之间的间隔是外边距(相似单元格的 cellspacing)
规范盒子模型
2. 盒子边框(border)
- 语法:
border : border-width || border-style || border-color
属性 | 作用 |
---|---|
border-width | 定义边框粗细,单位是px |
border-style | 边框的款式 |
border-color | 边框色彩 |
边框的款式:
- none:没有边框即疏忽所有边框的宽度(默认值)
- solid:边框为单实线(最为罕用的)
- dashed:边框为虚线
- dotted:边框为点线
2.1 边框综合设置
border : border-width || border-style || border-color
例如:
border: 1px solid red; 没有程序
2.2 盒子边框写法总结表
很多状况下,咱们不须要指定4个边框,咱们是能够独自给4个边框别离指定的。
上边框 | 下边框 | 左边框 | 左边框 |
---|---|---|---|
border-top-style:款式; | border-bottom-style:款式; | border-left-style:款式; | border-right-style:款式; |
border-top-width:宽度; | border- bottom-width:宽度; | border-left-width:宽度; | border-right-width:宽度; |
border-top-color:色彩; | border- bottom-color:色彩; | border-left-color:色彩; | border-right-color:色彩; |
border-top:宽度 款式 色彩; | border-bottom:宽度 款式 色彩; | border-left:宽度 款式 色彩; | border-right:宽度 款式 色彩; |
2.3 表格的细线边框
- 通过表格的
cellspacing="0"
,将单元格与单元格之间的间隔设置为0, - 然而两个单元格之间的边框会呈现重叠,从而使边框变粗
通过css属性:
table{ border-collapse:collapse; }
- collapse 单词是合并的意思
- border-collapse:collapse; 示意相邻边框合并在一起。
<style> table { width: 500px; height: 300px; border: 1px solid red; } td { border: 1px solid red; text-align: center; } table, td { border-collapse: collapse; /*合并相邻边框*/ }</style>
3. 内边距(padding)
3.1 内边距:
padding属性用于设置内边距。 是指 边框与内容之间的间隔。
3.2 设置
属性 | 作用 |
---|---|
padding-left | 左内边距 |
padding-right | 右内边距 |
padding-top | 上内边距 |
padding-bottom | 下内边距 |
当咱们给盒子指定padding值之后, 产生了2件事件:
- 内容和边框 有了间隔,增加了内边距。
- 盒子会变大了。
留神: 前面跟几个数值示意的意思是不一样的。
咱们离开写有点麻烦,咱们能够不能够简写呢?
值的个数 | 表白意思 |
---|---|
1个值 | padding:上下左右内边距; |
2个值 | padding: 高低内边距 左右内边距 ; |
3个值 | padding:上内边距 左右内边距 下内边距; |
4个值 | padding: 上内边距 右内边距 下内边距 左内边距 ; |
3.3 内盒尺寸计算(元素理论大小)
宽度
Element Height = content height + padding + border (Height为内容高度)
高度
Element Width = content width + padding + border (Width为内容宽度)
- 盒子的理论的大小 = 内容的宽度和高度 + 内边距 + 边框
3.4 内边距产生的问题
问题
会撑大原来的盒子
解决:
通过给设置了宽高的盒子,减去相应的内边距的值,维持盒子原有的大小
3.5 padding不影响盒子大小状况
如果没有给一个盒子指定宽度, 此时,如果给这个盒子指定padding, 则不会撑开盒子。
4. 外边距(margin)
4.1 外边距
margin属性用于设置外边距。 margin就是管制盒子和盒子之间的间隔
4.2 设置:
属性 | 作用 |
---|---|
margin-left | 左外边距 |
margin-right | 右外边距 |
margin-top | 上外边距 |
margin-bottom | 下外边距 |
margin值的简写 (复合写法)代表意思 跟 padding 完全相同。
4.3 块级盒子程度居中
能够让一个块级盒子实现程度居中必须:
- 盒子必须指定了宽度(width)
- 而后就给左右的外边距都设置为auto,
理论工作中罕用这种形式进行网页布局,示例代码如下:
.header{ width:960px; margin:0 auto;}
常见的写法,以下下三种都能够。
- margin-left: auto; margin-right: auto;
- margin: auto;
- margin: 0 auto;
4.4 文字居中和盒子居中区别
- 盒子内的文字水平居中是 text-align: center, 而且还能够让 行内元素和行内块居中对齐
- 块级盒子程度居中 左右margin 改为 auto
text-align: center; /* 文字 行内元素 行内块元素程度居中 */margin: 10px auto; /* 块级盒子程度居中 左右margin 改为 auto 就阔以了 高低margin都能够 */
4.5 插入图片和背景图片区别
- 插入图片 咱们用的最多 比方产品展现类 挪动地位只能靠盒模型 padding margin
- 背景图片咱们个别用于小图标背景 或者 超大背景图片 背景图片 只能通过 background-position
img { width: 200px;/* 插入图片更改大小 width 和 height */ height: 210px; margin-top: 30px; /* 插入图片更改地位 能够用margin 或padding 盒模型 */ margin-left: 50px; /* 插入当图片也是一个盒子 */ } div { width: 400px; height: 400px; border: 1px solid purple; background: #fff url(images/sun.jpg) no-repeat; background-position: 30px 50px; /* 背景图片更改地位 我用 background-position */ }
4.6 革除元素的默认内外边距(重要)
为了更灵便不便地管制网页中的元素,制作网页时,咱们须要将元素的默认内外边距革除
代码:
* { padding:0; /* 革除内边距 */ margin:0; /* 革除外边距 */}
留神:
- 行内元素为了关照兼容性, 尽量只设置左右内外边距, 不要设置高低内外边距。
4.7 外边距合并
应用margin定义块元素的垂直外边距时,可能会呈现外边距的合并。
(1). 相邻块元素垂直外边距的合并
- 当高低相邻的两个块元素相遇时,如果下面的元素有下外边距margin-bottom
- 上面的元素有上外边距margin-top,则他们之间的垂直间距不是margin-bottom与margin-top之和
取两个值中的较大者这种景象被称为相邻块元素垂直外边距的合并(也称外边距塌陷)。
解决方案:尽量给只给一个盒子增加margin值。
(2). 嵌套块元素垂直外边距的合并(塌陷)
- 对于两个嵌套关系的块元素,如果父元素没有上内边距及边框
- 父元素的上外边距会与子元素的上外边距产生合并
合并后的外边距为两者中的较大者
解决方案:
- 能够为父元素定义上边框。
- 能够为父元素定义上内边距
- 能够为父元素增加overflow:hidden。
还有其余办法,比方浮动、固定、相对定位的盒子不会有问题
5. 盒子模型布局稳定性
学习完盒子模型,内边距和外边距,什么状况下用内边距,什么状况下用外边距?
- 大部分状况下是能够混用的。 就是说,你用内边距也能够,用外边距也能够。 你感觉哪个不便,就用哪个。
咱们依据稳定性来分,倡议如下:
依照 优先应用 宽度 (width) 其次 应用内边距(padding) 再次 外边距(margin)。
width > padding > margin
起因:
- margin 会有外边距合并 还有 ie6上面margin 加倍的bug(厌恶)所以最初应用。
- padding 会影响盒子大小, 须要进行加减计算(麻烦) 其次应用。
- width 没有问题(嗨皮)咱们常常应用宽度残余法 高度残余法来做。
去掉列表默认的款式
无序和有序列表后面默认的列表款式,在不同浏览器显示成果不一样,而且也比拟难看,所以,咱们个别上来就间接去掉这些列表款式就行了。 代码如下
li { list-style: none; }
6.其余
6.1 圆角边框(CSS3)
- 语法:
border-radius:length;
- 其中每一个值能够为 数值或百分比的模式。
技巧: 让一个正方形 变成圆圈
border-radius: 50%;
- 以上效果图矩形的圆角, 就不要用 百分比了,因为百分比会是示意高度和宽度的一半。
- 而咱们这里矩形就只用 用 高度的一半就好了。准确单位。
6.2 盒子暗影(CSS3)
- 语法:
box-shadow:程度暗影 垂直暗影 含糊间隔(虚实) 暗影尺寸(影子大小) 暗影色彩 内/外暗影;
- 前两个属性是必须写的。其余的能够省略。
- 外暗影 (outset) 是默认的 然而不能写 想要内暗影能够写 inset
div { width: 200px; height: 200px; border: 10px solid red; /* box-shadow: 5px 5px 3px 4px rgba(0, 0, 0, .4); */ /* box-shadow:程度地位 垂直地位 含糊间隔 暗影尺寸(影子大小) 暗影色彩 内/外暗影; */ box-shadow: 0 15px 30px rgba(0, 0, 0, .4); }
6.3 CSS书写标准
空格标准
【强制】 选择器 与 { 之间必须蕴含空格。
示例:
.selector {}
【强制】 属性名 与之后的 : 之间不容许蕴含空格, : 与 属性值 之间必须蕴含空格。
示例:
font-size: 12px;
选择器标准
【强制】 并集选择器,每个选择器申明必须独占一行。
示例:
/* good */.post,.page,.comment { line-height: 1.5;}/* bad */.post, .page, .comment { line-height: 1.5;}
【倡议】 个别状况状况下,选择器的嵌套层级应不大于 3 级,地位靠后的限定条件应尽可能准确。
示例:
/* good */#username input {}.comment .avatar {}/* bad */.page .header .login input {}.comment div * {}
属性标准
【强制】 属性定义必须另起一行。
示例:
/* good */.selector { margin: 0; padding: 0;}/* bad */.selector { margin: 0; padding: 0; }
【强制】 属性定义后必须以分号结尾。
示例:
/* good */.selector { margin: 0;}/* bad */.selector { margin: 0}
7. 浮动(float)
7.1 CSS 布局的三种机制
网页布局的外围——就是用 CSS 来摆放盒子。
CSS 提供了 3 种机制来设置盒子的摆放地位,别离是一般流(规范流)、浮动和定位,其中:
一般流(规范流)
块级元素会独占一行,从上向下顺序排列;
- 罕用元素:div、hr、p、h1~h6、ul、ol、dl、form、table
行内元素会依照程序,从左到右顺序排列,碰到父元素边缘则主动换行;
- 罕用元素:span、a、i、em等
浮动
- 让盒子从一般流中浮起来,次要作用让多个块级盒子一行显示。
定位
- 将盒子定在浏览器的某一个位置——CSS 离不开定位,特地是前面的 js 特效。
7.2 为什么须要浮动?
思考题:
咱们首先要思考以下2个布局中最常见的问题?
- 如何让多个盒子(div)程度排列成一行?
- 如何实现盒子的左右对齐?
尽管咱们后面学过行内块(inline-block) 然而他却有本人的缺点:
- 它能够实现多个元素一行显示,然而两头会有空白缝隙,不能满足以上第一个问题。
- 它不能实现以上第二个问题,盒子左右对齐
因为一些网页布局要求,规范流不能满足咱们的须要了,因而咱们须要浮动来实现网页布局。
7.3 什么是浮动(float)
概念:元素的浮动是指设置了浮动属性的元素会
- 脱离规范一般流的管制
- 挪动到指定地位。
作用
- 让多个盒子(div)程度排列成一行,使得浮动成为布局的重要伎俩。
- 能够实现盒子的左右对齐等等..
- 浮动最早是用来管制图片,实现文字盘绕图片的成果。
语法
在 CSS 中,通过 float
中文, 浮 漏 特 属性定义浮动,语法如下:
选择器 { float: 属性值; }
属性值 | 形容 |
---|---|
none | 元素不浮动(默认值) |
left | 元素向左浮动 |
right | 元素向右浮动 |
浮动口诀。通过 float
----- 浮 漏 特
1). 浮动口诀之 浮
沉没在一般流的下面。 脱离规范流。 俗称 “脱标”
.box1 { width: 200px; height: 200px; background-color: rgba(255, 0, 0, 0.5); float: left;}.box2 { width: 150px; height: 300px; background-color: skyblue;}
小结:
float
属性会让盒子沉没在规范流的下面,所以第二个规范流的盒子跑到浮动盒子的底下了。
2). 浮动口诀之 漏
浮动的盒子,把本人原来的地位漏给上面规范流的盒子,就是不占有原来地位,是脱离规范流的,咱们俗称 “脱标”。
.box1 { width: 200px; height: 200px; background-color: rgba(255, 0, 0, 0.5); /* 让第 1 个盒子沉没起来,不占地位 */ float: left;}.box2 { width: 150px; height: 300px; background-color: skyblue;}
所以,box2上面的其实就是跑到box1盒子上面了, 被box1给压住了,遮挡起来了
3). 浮动口诀之 特
float属性会扭转元素display属性。
任何元素都能够浮动。浮动元素会生成一个块级框,而不管它自身是何种元素。 生成的块级框和咱们后面的行内块极其类似。
div 程度排列
div { width: 200px; height: 200px; background-color: pink; /* 转换为行内块元素,能够程度显示,不过 div 之间有间隙,不不便解决 */ /* display: inline-block; */ /* 设置浮动属性,能够让 div 程度排列,并且没有间隙 */ float: left;}.two { background-color: hotpink;}
留神: 浮动的元素相互贴靠一起的,然而如果父级宽度装不下这些浮动的盒子, 多出的盒子会另起一行对齐
7.4 浮动(float)小结
咱们应用浮动的外围目标——让多个块级盒子在同一行显示。 因为这是咱们最常见的一种布局形式
float —— 浮漏特
特点 | 阐明 |
---|---|
浮 | 加了浮动的盒子是浮起来的,沉没在其余规范流盒子的下面。 |
漏 | 加了浮动的盒子是不占地位的,它原来的地位漏给了规范流的盒子。 |
特 | 特地留神:浮动元素会扭转display属性, 相似转换为了行内块,然而元素之间没有空白缝隙 |
7.5 浮动(float)的利用(重要)
浮动和规范流的父盒子搭配
咱们晓得,浮动是脱标的,会影响上面的规范流元素,此时,咱们须要给浮动的元素增加一个规范流的父亲,这样,最大化的减小了对其余规范流的影响。
导航栏案例
留神,理论重要的导航栏中,咱们不会间接用链接a 而是用 li 蕴含链接(li+a)的做法。
- li+a 语义更清晰,一看这就是有条理的列表型内容。
- 如果间接用a,搜索引擎容易分别为有堆砌关键字嫌疑(成心堆砌关键字容易被搜索引擎有降权的危险),从而影响网站排名
7.6 浮动(float)的扩大
1). 浮动元素与父盒子的关系
- 子盒子的浮动参照父盒子对齐
- 不会与父盒子的边框重叠,也不会超过父盒子的内边距
2). 浮动元素与兄弟盒子的关系
在一个父级盒子中,如果前一个兄弟盒子是:
- 浮动的,那么以后盒子会与前一个盒子的顶部对齐;
- 一般流的,那么以后盒子会显示在前一个兄弟盒子的下方。
浮动只会影响以后的或者是前面的规范流盒子,不会影响后面的规范流。
倡议
如果一个盒子外面有多个子盒子,如果其中一个盒子浮动了,其余兄弟也应该浮动。避免引起问题
8. 革除浮动
8.1 为什么要革除浮动
因为父级盒子很多状况下,不不便给高度,然而子盒子浮动就不占有地位,最初父级盒子高度为0,就影响了上面的规范流盒子。
总结:
- 因为浮动元素不再占用原文档流的地位,所以它会对前面的元素排版产生影响
- 精确地说,并不是革除浮动,而是革除浮动后造成的影响
8.2 革除浮动实质
革除浮动次要为了解决父级元素因为子级浮动引起外部高度为0 的问题。革除浮动之后, 父级就会依据浮动的子盒子自动检测高度。父级有了高度,就不会影响上面的规范流了
8.3 革除浮动的办法
在CSS中,clear属性用于革除浮动
- 语法:
选择器{clear:属性值;} clear 革除
属性值 | 形容 |
---|---|
left | 不容许左侧有浮动元素(革除左侧浮动的影响) |
right | 不容许右侧有浮动元素(革除右侧浮动的影响) |
both | 同时革除左右两侧浮动的影响 |
然而咱们理论工作中, 简直只用 clear: both;
1).额定标签法(隔墙法)
是W3C举荐的做法是通过在浮动元素开端增加一个空的标签例如 <div style=”clear:both”></div>,或则其余标签br等亦可。
- 长处: 通俗易懂,书写不便
- 毛病: 增加许多无意义的标签,结构化较差。
2).父级增加overflow属性办法
能够给父级增加: overflow为 hidden| auto| scroll 都能够实现。
长处: 代码简洁
毛病: 内容增多时候容易造成不会主动换行导致内容被暗藏掉,无奈显示须要溢出的元素。
3).应用after伪元素革除浮动
:after 形式为空元素额定标签法的升级版,益处是不必独自加标签了
应用办法:
.clearfix:after { content: ""; display: block; height: 0; clear: both; visibility: hidden; } .clearfix {*zoom: 1;} /* IE6、7 专有 */
- 长处: 合乎闭合浮动思维 构造语义化正确
- 毛病: 因为IE6-7不反对:after,应用 zoom:1触发 hasLayout。
- 代表网站: 百度、淘宝网、网易等
4).应用双伪元素革除浮动
应用办法:
.clearfix:before,.clearfix:after { content:""; display:table; }.clearfix:after { clear:both;}.clearfix { *zoom:1;}
- 长处: 代码更简洁
- 毛病: 因为IE6-7不反对:after,应用 zoom:1触发 hasLayout。
- 代表网站: 小米、腾讯等
8.4 革除浮动总结
什么时候用革除浮动呢?
- 父级没高度
- 子盒子浮动了
- 影响上面布局了,咱们就应该革除浮动了。
革除浮动的形式 | 长处 | 毛病 |
---|---|---|
额定标签法(隔墙法) | 通俗易懂,书写不便 | 增加许多无意义的标签,结构化较差。 |
父级overflow:hidden; | 书写简略 | 溢出暗藏 |
父级after伪元素 | 构造语义化正确 | 因为IE6-7不反对:after,兼容性问题 |
父级双伪元素 | 构造语义化正确 | 因为IE6-7不反对:after,兼容性问题 |
9.定位(position)
9.1 CSS 布局的三种机制
网页布局的外围 —— 就是用 CSS 来摆放盒子地位。
CSS 提供了 3 种机制来设置盒子的摆放地位,别离是一般流、浮动和定位,其中:
- 一般流(规范流)
浮动
- 让盒子从一般流中浮起来 —— 让多个盒子(div)程度排列成一行。
定位
- 将盒子定在某一个位置 自在的沉没在其余盒子的下面 —— CSS 离不开定位,特地是前面的 js 特效。
9.2 为什么应用定位
将盒子定在某一个位置 自在的沉没在其余盒子(包含规范流和浮动)的下面
所以,咱们脑海应该有三种布局机制的高低程序
规范流在最底层 (海底) ------- 浮动 的盒子 在 中间层 (海面) ------- 定位的盒子 在 最上层 (天空)
9.3 定位详解
定位也是用来布局的,它有两局部组成:
定位 = 定位模式 + 边偏移
9.3.1 边偏移
简略说, 咱们定位的盒子,是通过边偏移来挪动地位的。
在 CSS 中,通过 top
、bottom
、left
和 right
属性定义元素的边偏移:(方位名词)
边偏移属性 | 示例 | 形容 |
---|---|---|
top | top: 80px | 顶端偏移量,定义元素绝对于其父元素上边线的间隔。 |
bottom | bottom: 80px | 底部偏移量,定义元素绝对于其父元素下边线的间隔。 |
left | left: 80px | 左侧偏移量,定义元素绝对于其父元素右边线的间隔。 |
right | right: 80px | 右侧偏移量,定义元素绝对于其父元素左边线的间隔 |
定位的盒子有了边偏移才有价值。 个别状况下,但凡有定位中央必然有边偏移。
9.3.2 定位模式 (position)
在 CSS 中,通过 position
属性定义元素的定位模式,语法如下:
选择器 { position: 属性值; }
定位模式是有不同分类的,在不同状况下,咱们用到不同的定位模式。
值 | 语义 |
---|---|
static | 动态定位 |
relative | 绝对定位 |
absolute | 相对定位 |
fixed | 固定定位 |
动态定位(static) - 理解
- 动态定位是元素的默认定位形式,无定位的意思。它相当于 border 外面的none, 不要定位的时候用。
- 动态定位 依照规范流个性摆放地位,它没有边偏移。
- 动态定位在布局时咱们简直不必的
绝对定位(relative) - 重要
- 绝对定位是元素绝对于它 原来在规范流中的地位 来说的。
效果图:
绝对定位的特点:(务必记住)
- 绝对于 本人原来在规范流中地位来挪动的
- 原来在规范流的区域持续占有,前面的盒子依然以规范流的形式看待它。
相对定位(absolute) - 重要
相对定位是元素以带有定位的父级元素来挪动地位
- 齐全脱标 —— 齐全不占地位;
- 父元素没有定位,则以浏览器为准定位(Document 文档)。
父元素要有定位
- 将元素根据最近的曾经定位(相对、固定或绝对定位)的父元素(先人)进行定位。
相对定位的特点:(务必记住)
- 相对是以带有定位的父级元素来挪动地位如果父级都没有定位,则以浏览器文档为准挪动地位
- 不保留原来的地位,齐全是脱标的。
因为相对定位的盒子是拼爹的,所以要和父级搭配一起来应用。
定位口诀 —— 子绝父相
相对定位,要和带有定位的父级搭配应用,那么父级要用什么定位呢?
子绝父相 —— 子级是相对定位,父级要用绝对定位。
论断:父级要占有地位,子级要任意摆放,这就是子绝父相的由来。
固定定位(fixed) - 重要
固定定位是相对定位的一种非凡模式
- 齐全脱标 —— 齐全不占地位;
只认浏览器的可视窗口 ——
浏览器可视窗口 + 边偏移属性
来设置元素的地位;- 跟父元素没有任何关系;独自应用的
- 不随滚动条滚动。
提醒:IE 6 等低版本浏览器不反对固定定位。
9.4 定位(position)的扩大
9.4.1 相对定位的盒子居中
留神:相对定位/固定定位的盒子不能通过设置 margin: auto
设置程度居中。
在应用相对定位时要想实现程度居中,能够依照下图的办法:
left: 50%;
:让盒子的左侧挪动到父级元素的程度核心地位;margin-left: -100px;
:让盒子向左挪动本身宽度的一半。
盒子居中定位示意图
9.4.2 重叠程序(z-index)
在应用定位布局时,可能会呈现盒子重叠的状况。
加了定位的盒子,默认后来者居上, 前面的盒子会压住后面的盒子。
利用 z-index
层叠等级属性能够调整盒子的重叠程序。如下图所示:
z-index
的个性如下:
- 属性值:正整数、负整数或 0,默认值是 0,数值越大,盒子越靠上;
- 如果属性值雷同,则依照书写程序,青出于蓝;
- 数字前面不能加单位。
留神:z-index
只能利用于绝对定位、相对定位和固定定位的元素,其余规范流、浮动和动态定位有效。
9.4.3 定位扭转display属性
后面咱们讲过, display 是 显示模式, 能够扭转显示模式有以下形式:
- 能够用inline-block 转换为行内块
- 能够用浮动 float 默认转换为行内块(相似,并不齐全一样,因为浮动是脱标的)
- 相对定位和固定定位也和浮动相似, 默认转换的个性 转换为行内块。
所以说, 一个行内的盒子,如果加了浮动、固定定位和相对定位,不必转换,就能够给这个盒子间接设置宽度和高度等。
同时留神:
浮动元素、相对定位(固定定位)元素的都不会触发外边距合并的问题。 (咱们以前是用padding border overflow解决的)
也就是说,咱们给盒子改为了浮动或者定位,就不会有垂直外边距合并的问题了。
圆角矩形设置4个角
圆角矩形能够为4个角别离设置圆度, 然而是有程序的
border-top-left-radius:20px;border-top-right-radius:20px;border-bottom-right-radius:20px;border-bottom-left-radius:20px;
- 如果4个角,数值雷同
border-radius: 15px;
- 外面数值不同,咱们也能够依照简写的模式,具体格局如下:
border-radius: 左上角 右上角 右下角 左下角;
还是遵循的顺时针。
9.5 定位小结
定位模式 | 是否脱标占有地位 | 挪动地位基准 | 模式转换(行内块) | 应用状况 |
---|---|---|---|---|
动态static | 不脱标,失常模式 | 失常模式 | 不能 | 简直不必 |
绝对定位relative | 不脱标,占有地位 | 绝对本身地位挪动 | 不能 | 根本独自应用 |
相对定位absolute | 齐全脱标,不占有地位 | 绝对于定位父级挪动地位 | 能 | 要和定位父级元素搭配应用 |
固定定位fixed | 齐全脱标,不占有地位 | 绝对于浏览器挪动地位 | 能 | 独自应用,不须要父级 |
留神:
- 边偏移须要和定位模式联结应用,独自应用有效;
top
和bottom
不要同时应用;left
和right
不要同时应用。