盒模式是 CSS 中一个重要的概念,即元素在页面所占据的空间位置,盒模型的属性包括:内容 (content)、填充 (padding)、边框 (border)、边界 (margin),盒模型一共分为两种,一种是 W3C 标准盒模型,另一种是 IE 盒模型(又称怪异盒模型)
元素盒模型宽高 = 内容的宽高 + 内边距padding + 边框border + 外边距margin
背景颜色从 border-box 开始生效的,背景图像从 padding-box 开始生效的,CSS 3 属性 : content-box / padding-box / border-box 可以改变背景图像从盒模型的哪部分开始生效
通过盒模型的外边距 margin 拉开各元素之间的间隙、距离,使用 padding 来撑开自身的宽高
在低版本 IE 里,若不添加 <!DOCTYPE html> 的文档声明,就会按照 IE 盒模型进行解析
元素盒模型宽高 = 内容的宽高【元素的宽高 + padding + border】 + 外边距margin
IE 盒模型的计算方式和 W3C 的盒模型很相似,但有一点是非常不同的,这就是:内边距和边框并不被包含在计算的范围内,这就意味着,如果元素也有内边距 padding 和边框 border ,那么实际内容区域将会缩小,为它们腾出空间
在实际设计中,我们会发现,IE 盒模型更容易进行控制,我们一般先将整个容器的尺寸先确定,然后再填充具体的内容,通过 padding 来调整内容的具体位置,通过 margin 来调整容器与其他元素之间的间隙,无论如何调整,整个容器的结构是固定的,不会改变的;而在标准盒模型中,我们在调整 padding 和 margin 的同时,往往会将容器本身的结构打乱,需要重新设置内容 content 的尺寸
CSS 3 属性: box-sizing: border-box 可以让元素按照 IE 盒模型进行解析,即设置的宽高包括了 border 以及 padding 的值
display 属性,元素的显示方式,规定元素应该生成的框的类型,这个属性用于定义建立布局时元素生成的显示框类型
注释 : inline-block 在 IE7 开始支持,在 IE6 下设置 _display:inline 也可以实现相同效果,下划线 _ 是只针对 IE6 所设置的 CSS 样式,例: _width:100px
我们来回顾下块元素和行元素的特点,块元素的特点: 竖直排列,可以设置宽高,宽度占满整行,即宽度 100%,另起新行 ;行元素的特点: 水平排列,设置宽高不生效,宽度由内容决定,高度由行高决定 ,这是我们之前已经了解过的,那么它们设置内外边距的特点又是什么呢?我们来尝试一下
由运行结果可以得知, 行元素在竖直方向上设置的 margin 不生效,水平方向上设置的 margin 叠加
由运行结果可以得知, 行元素在水平方向上设置的 padding 生效,竖直方向上的不生效 ,虽然元素的范围增大了,但是,由于行元素的高度是由内容决定的,所以加了上下 padding 以后会与临近行的元素产生干涉
所以,行元素建议尽量不要设置上下的内 / 外边距,即 padding-top , padding-bottom 和 margin-top , margin-bottom ,因为要么起不到效果,要么看起来有效实则容易引起布局混乱
由运行结果可以得知, 块元素在竖直方向上设置的 margin 以大的 margin 来计算 ,因为块元素宽度默认占满整行,设置内边距 padding 和水平方向上的外边距 margin 只会调整元素的位置,在这里就不再验证
行元素在竖直方向上设置的 margin / padding 不生效,水平生效
块元素在竖直方向上设置的 margin 会重叠,大的那个值生效
行元素在水平方向上设置的 margin / padding 不会重叠,水平相加
设置了 inline-block 属性之后,行元素就具有块元素的特点【可以设置宽高;竖直方向上的 padding/margin 生效】,块元素就可以水平排列
display:none 和 visibility:hidden 都能把网页上某个元素隐藏起来,但两者是有区别的:
display:none 不为被隐藏的对象保留其物理空间,即该对象在页面上彻底消失,不占据空间位置,完全消失
visibility:hidden 使对象在网页上不可见,但该对象在网页上所占的空间没有改变,还占据原来的空间位置,可以理解为透明
让有宽度【非宽度100%】的 块元素水平居中 : margin:0 auto
设置 单行文本的竖直居中 : line-height: 该元素高度
行元素水平居中 :给行元素的父级添加 text-alingn:center
text-align:center/left/right 设置块元素中的内容文本、图片的对齐方式,只能设置在块元素,在行元素中设置无效
行文过程中出现错误或不妥之处在所难免,希望大家能够给予指正,以免误导更多人,最后,如果你觉得我的文章写的还不错,希望能够点一下 喜欢 和 关注 ,为了我能早日成为优秀作者献上一发助攻吧,谢谢!^ ^
CSS盒模型:将页面所有元素表示为一个个矩形的盒子,CSS决定这些盒子的大小,位置以及属性。
<h1>...<h6>、<p>、<div>、<ul>、<ol>、<li>、<dl>、<dt>、<dd>、<header>、<main>、<footer>、<aside>、<nav>、<section>、<table>、<pre>
<a>、<span>、<em>、<strong>、<img>、<input>、<label>、<textarea>、<select>、<button>、<code>
1. 写法:display: inline-block
2. 特性:
3. inline-block缝隙 css常见样式二
4. display的值
②:浮动元素和绝对定位元素的外边距不会折叠。
PS:
PS:通过设置margin让元素居中
1.3.1 设置边框的值
1.3.2 边框常用属性
实现效果:
参考:
https://static.xiedaimala.com/xdml/file/f40ceb64-df08-4420-9226-7f76dbff15d5/2019-11-6-10-45-8.pdf
https://developer.mozilla.org/zh-CN/docs/Learn/CSS/Building_blocks/The_box_model
在CSS中,所有元素被“ 盒子 ”所包围,利用盒模型的基本原理来实现CSS准确布局,元素排列等处理
CSS广泛使用的两种盒子,其在页面流和元素之间的关系表现为不同的行为:
对于定义为块级盒子(block)的元素会表现出以下行为:
对于定义为内联盒子(inline)的元素会表现出以下行为:
通过对盒子设置display的属性值,来控制盒子的外部显示类型
外部显示类型与内部显示类型
外部显示类型:决定盒子是块级还是内联,即决定了盒子之间的布局方式
内部显示类型:决定了盒子内部的元素是如何布局的,默认情况是按照正常文档流布局,也可以通过设置display值为flex和grid来改变内部元素之间的布局方式
不同显示类型的例子
block:
图中段落里的 <span>word </span>被设置为 display:block
因此其独占一行,宽度填满整个父元素
flex:
图中的列表被设置为 display:block ,每个列表是一个块级元素 —— 像段落一样 —— 会充满整个容器的宽度并且换行
inline-flex与inline
图中的列表被设置为 display:inline-flex ,使得在一些flex元素外创建一个内联框
最后设置两个段落为 display: inline , inline flex 容器和两个段落在同一行上,而不是像块级元素一样换行
CSS组成一个盒模型需要以下几个部分:
在标准模型中,如果你给盒设置 width 和 height,实际设置的是 content box。 padding 和 border 再加上设置的宽高一起决定整个盒子的大小
如果使用标准模型宽度 = 410px (350 + 25 + 25 + 5 + 5),高度 = 210px (150 + 25 + 25 + 5 + 5),padding 加 border 再加 content box
如果使用替代模型,一切都将变得简单很多,此时的 width 和 height 就是盒子可见的宽度与高度,无论怎么改变 padding 或 border 的值,都会通过压缩 conten box 的大小来保持 width 和 height 的值不变
如需使用,只需要声明以下CSS样式:
外边距是盒子周围一圈看不到的空间。它会把其他元素从盒子旁边推开。 外边距属性值可以为正也可以为负。设置负值会导致和其他内容重叠。无论使用标准模型还是替代模型,外边距总是在计算可见部分后额外添加
CSS:
html:
结果如下:因为上外边距设置为负值,所以两个边框会重叠
外边距折叠
理解外边距的一个关键是外边距折叠的概念。如果你有两个外边距相接的元素,这些外边距将合并为一个外边距,即最大的单个外边距的大小
结果如下,中间间隔的部分为50px
如下图所示,对内联盒子设置 width 和 height 都不会生效,虽然margin,padding和border会生效,但不会改变与其它内联盒子的关系,因此其内边距和边框会与段落的其它元素重叠
要避免上述情况,只需要将内联盒子的display值设置为inline-block即可
设置之后的效果为:
但因其保留有inline的特征,所以它不会跳转到新行
float可以使得当前元素脱离正常文本流,并吸附到父元素的左边(left)或者右边(right)正常布局中位于该浮动元素之下的内容,此时会围绕着浮动元素进行排列
基本的常见用途在于图片与文字环绕排版以及首字母下沉:
重点是这个,元素浮动具有一定的规则与限制
设置如下三个盒子(均以块级元素方式呈现):
将box1设置为向右浮动:
因为box1脱离正常文档流,所以box2和box3会向上填补box1的空位,box1浮动到父元素(body)的最右边
设置box1向左浮动:
同理,box1脱离正常文档流,box2与box3向上填补box1的空位,此时box1浮动到父元素(body)的最左边,所以会覆盖掉box2(浮动元素在正常流文档的上方)
设置box2向左浮动:
可以看到box3因为box2脱离正常文档流而向上填充其空位,box2因为浮动到左边覆盖了box3,然而box1仍处于正常文档流中,并且在html文件中最先声明,所以box2只能在box1的下方进行浮动(即使box2设置为向右浮动也是一样)
设置box1、box2与box3都向左浮动:
可以看到三个盒子均向左浮动,直到碰到前一个浮动框的边缘为止(对于box1来说是碰到父元素的边缘),因此呈现如此的排列状况
如果当父元素太窄,无法包含三个盒子的宽度,则无法容纳的元素向下移动,直到有足够的空间使得其能向某个方向浮动,如下图所示:
如果浮动元素的高度不同,那么当它们向下移动时可能被其它浮动元素“卡住”
相关参考:
https://zhuanlan.zhihu.com/p/21286019?refer=miaomiaoji
https://www.jianshu.com/p/fe1052f1a8b6
浮动的规则先讨论到此
高度塌陷
在父元素container内设置一个盒子box1,此时没有设置浮动,box1会撑起父元素container的高度
如果此时设置box1浮动,因为其脱离了正常文档流,无法撑起盒子的高度,所以将发生高度塌陷:
为了解决这个问题,在此提供三种方法:
1. 添加额外标签
首先在父元素内添加空白内容的额外标签clearfix
然后再CSS规则中添加以下内容:
通过清除父元素内空白元素的浮动,使得父元素边框重新包含浮动内容
2. 父级元素添加overflow属性
直接在父元素内添加overflow属性:
同样可以清除浮动,结果如下:
3. after伪元素
html文档改为:
在CSS规则里添加: