css样式基础之盒子模型

CSS中, Box Model叫盒子模型(或框模型),Box Model规定了元素框处理元素内容(element content)、内边距(padding)、边框(border) 和 外边距(margin) 的方式。
在w3c中,有这样一幅图:
这里写图片描述

每个元素都有盒子模型,其实这东西了解起来也简单:把元素想象成一个衣柜,我们在衣柜中放的衣服其实就是图中的元素,衣服跟衣柜之间的空隙其实就是内边距,衣柜的厚度其实就是边框,我们把衣柜摆在房间的哪个位置,衣柜与房间的空隙就是外边距。

其实盒子模型我们理解好了后面就很好控制了。
我们重点要注意的是(个人总结):
1、盒子模型的大小计算
看代码:

/*样式*/
<style>
    *{margin: 0;padding: 0px;}
    #box{
        width: 300px;
        height: 280px;
        background: antiquewhite;
    }
</style>

/* html */
<body>
    <div id="box">
    </div>
</body>

我们运行的结果其实就是一个div,长宽分别是300px,280px。
如果我在样式中加入margin: 20px,则长宽就分别加多40px;如果在样式中再加入pandding:20px,则长宽就分别再加多40px;如果再样式中再加入border: 20px solid red,则长宽再加多40px。
规律就是div的大小在原来设置的width,height上,继续增加外边局,内边距以及边宽的长度。
2、box-sizing的使用
box-sizing这货其实用起来挺方便的,要是没接触过这货的话,有些东西做起来真的比较吃梨。因为有时候,我们定死一个div的高宽后,只想改变内部的大小而已,而不影响整个div的大小,这时候就得用上box-sizing了。
box-sizing有两个属性:border-box以及content-box。
看代码(html还是原来的):

*{margin: 0;padding: 0px;}
#box{
    width: 300px;
    height: 280px;
    background: antiquewhite;
    border: 100px solid saddlebrown;
    box-sizing: content-box;
}

这个时候,div的大小是呗这个border撑大了,也就是跟我门之前的一样的计算方法。如果我们把box-sizing: content-box修改成为box-sizing: border-box,边框的大小就不会将整个div给撑大了,它只会占用div内部的大小。如图:
这里写图片描述

额,有点夸张,褐色其实就是边框的大小整个整个大小其实还是我们样式中涉及到的width: 300px;height: 280px。

总结:

每个元素都有盒子模型,在做东西的时候心中要有数,牢记盒子的计算规律。
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值