共计 10537 个字符,预计需要花费 27 分钟才能阅读完成。
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
不要同时应用。