本文摘自PHP中文网,作者V,侵删。
css盒模型的属性有:1、margin属性;2、border属性;3、transparent属性;4、padding属性。

本教程操作环境:windows10系统、css3,本文适用于所有品牌的电脑。
CSS盒模型是定义元素周围的间隔、尺寸、外边距、边框以及文本内容和边框之间内边距的一组属性的集合。
(学习视频推荐:css视频教程)
示例代码:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 | <!DOCTYPE html>
< html >
< head >
< meta charset = "UTF-8" >
< title >Document</ title >
< style type = "text/css" >
*{margin: 0;padding: 0;}
.boxWrapper{
width: 150px;
height: 150px;
background: #ccc;
margin: 20px 20px 20px 20px;
padding: 20px 20px 20px 20px;
border: 20px solid #00f;
}
.boxInner{
width: 100px;
height: 100px;
border: 10px solid #000;
}
</ style >
</ head >
< body >
< div >
< div ></ div >
</ div >
</ body >
</ html >
|
效果图:

由此可见:外边距margin是不可见的,如果设置了父元素的背景,就可以看到;背景色在边框区域设置一个不同的背景,就可以看到内边距(padding)区域。并且盒模型是由margin(外边界)+border(边框)+padding(内边距)+content(内容)构成的。
二、属性介绍
1、margin属性
概念:margin属性应用于盒子外面的空间,或者是位于盒子与文档中其他元素之间的区域,或者是盒子与浏览器窗口之间的区域。margin长在盒子外围的,不会对盒子本身的大小造成影响。
属性:margin-top(上外边界)、margin-right(右外边界)、margin-bottom(下外边界)、margin-left(左外边界)
值:支持length、百分比、auto
用法:
1 2 3 4 5 6 | margin:10px 四周(上,右,下,左)
margin:10px 20px 上下 左右
margin:10px 20px 30px 上 左右 下
margin:10px 20px 30px 40px 上右下左
margin支持负值!!
让子元素在父元素里面左右居中:margin:0 auto;
|
margin常见的bug:
a:当父元素和子元素都没有浮动的情况下:给第一个子元素添加margin-top:会错误的把margin值加在父元素上面
实例代码:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 | <!DOCTYPE html>
< html >
< head >
< meta charset = "UTF-8" >
< title >Document</ title >
< style type = "text/css" >
*{margin: 0;padding: 0;}
.boxWrapper{
width: 150px;
height: 150px;
background: #ccc;
}
.boxInner{
width: 100px;
height: 100px;
margin-top: 20px;
background: skyblue;
}
.other{
width: 50px;
height: 50px;
background: #999;
/* margin-top: 20px; */
}
</ style >
</ head >
< body >
< div >
< div ></ div >
< div ></ div >
</ div >
</ body >
</ html >
|
效果图:

结论:当父元素里的第一个子元素(块元素),添加margin-top的时候,会错误的把margin-top的值添加给父元素(建立在当前的元素们,没有添加边框和浮动的前提下)
解决方法:
1、bfc 给父元素添加overflow:hidden;推荐使用
2、给父元素和子元素添加浮动属性;
3、可以给父元素添加边框
4、把margin改为padding
b:相邻两个元素上下margin会重叠,按照较大的值设置。
示例代码:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 | .boxInner{
width: 100px;
height: 100px;
margin-bottom: 20px;
background: skyblue;
}
.other{
width: 50px;
height: 50px;
background: #999;
margin-top: 20px;
}
</ style >
</ head >
< body >
< div class = "boxWrapper" >
< div class = "boxInner" ></ div >
< div class = "other" ></ div >
</ div >
</ body >
</ html >
|
效果图:

可以看出外边距折叠。当boxInner的下外边距和other元素的上外边距接触时,外边距发生了折叠!,他们之间只有20px,而不是40px;
2、边框
border属性:用来控制盒边框的宽度,样式,颜色。
属性:值(不支持百分比)常用px
1 2 3 4 | border:10px solid red;
border-width:10px;
border-style:solid;
border-color:red;
|
线性: solid(实线) dashed(虚线) dotted(点状线) double(双线) none/0(没有边框)
给单一一个方向添加边框:
1 | border- left / right / top / bottom : 10px solid yellow;
|
边框设置方法;
1 2 3 4 5 6 | border:solid red;
border-width:;
一个值:四周
两个值:上下 左右
三个值:上 左右 下
四个值:上右下左
|
3、transparent; 代替颜色值 为 透明
4、padding属性:内边距是元素的内容和边框之间的区域
用法:
1 2 3 4 5 6 7 8 9 10 11 12 | 1:padding是添加在父元素(盒子)上的
2:padding 调整子元素在父元素里面的位置关系
3:padding会把盒子撑大。
4:想让盒子保持原有的大小:在宽高的基础上减掉padding值。
5:给单一一个方向添加padding值: padding-top/bottom/left/right:
6:padding设置方法:
padding:10px 四周
padding:10px 20px 上下 左右
padding:10px 20px 30px 上 左右 下
padding:10px 20px 30px 40px 上右下左
7:padding不会对背景图造成影响
8:padding的值不能为负值!!!
|
对比padding和margin
1 2 3 4 | 1.padding区域是边框内边缘和内容外边缘之间的区域。
2.auto关键字对padding属性不起作用。
3.padding属性不可以接受复制。
4.padding不存在内边距折叠,只有外边距折叠。
|
相关推荐:CSS教程
以上就是css盒模型有哪些属性的详细内容,更多文章请关注木庄网络博客!
相关阅读 >>
css中如何给整个页面添加背景颜色
详解三种css3模糊背景效果(代码实例)
css right属性不起作用怎么办
css after是什么
css怎么改变图片颜色
html中iframe是如何使用的?
使用css实现自适应标题浮动效果(代码实例)
css怎么让文字在底部对齐
css的三种常用写法是什么
css怎么设置不能选中文字
更多相关阅读请进入《css》频道 >>
人民邮电出版社
本书对 Vue.js 3 技术细节的分析非常可靠,对于需要深入理解 Vue.js 3 的用户会有很大的帮助。——尤雨溪,Vue.js作者
转载请注明出处:木庄网络博客 » css盒模型有哪些属性