css盒模型有哪些属性


本文摘自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>

效果图:

2f873e276c377da973c90e8c5b8f8de.png

由此可见:外边距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>

效果图:

32d499c66f009e54ce966a373e2884d.png

结论:当父元素里的第一个子元素(块元素),添加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>

效果图:

deb3a32e045e6155e3440950bc2a9c2.png

可以看出外边距折叠。当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》频道 >>




打赏

取消

感谢您的支持,我会继续努力的!

扫码支持
扫码打赏,您说多少就多少

打开支付宝扫一扫,即可进行扫码打赏哦

分享从这里开始,精彩与您同在

评论

管理员已关闭评论功能...