打开APP
userphoto
未登录

开通VIP,畅享免费电子书等14项超值服

开通VIP
css中border-sizing属性详解和应用

box-sizing用于更改用于计算元素宽度和高度的默认的 css 盒子模型。它有content-box、border-box和inherit三种取值。inherit指的是从父元素继承box-sizing表现形式,不再冗赘。

1. 属性讲解

content-box

默认值,也是css2.1中的盒子模型。在计算width和height时候,不计算border、padding和margin。高度、宽度都只是内容高度

border-box

css3新增。 width和height属性包括内容,内边距和边框,但不包括外边距。

计算公式:

  1. width = width = border + padding + 内容宽度

  2. height = border + padding + 内容高度

2. 考虑盒子模型的margin

从上面可以知道,即时是border-box也是不计算margin,只是多余计算了border和padding。因为border和padding都是盒子模型的一部分,但是margin标记的是盒子和盒子的间距。所以,border-box的解释很符合常理。

问题来了,如果有时候一定要设置margin,怎么做到自由控制来保证兼容?例如,我们下面要设置一个撑满页面的盒子元素,而且有外边距干扰,怎么做?  

实现如下效果图:

代码

<!DOCTYPE html><html lang="en"><head>  <meta charset="UTF-8">  <meta name="viewport" content="width=device-width, initial-scale=1.0">  <meta http-equiv="X-UA-Compatible" content="ie=edge">  <title>yuanxin.me</title>  <style type="text/css">    *{      margin: 0;      padding: 0;    }    #app {      box-sizing: border-box; /* 指定计算方式 */      margin: 10px; /* 外边距干扰 */      /* 利用 css3 的 calc */      width: calc(100vw - 2*10px);      height: calc(100vh - 2*10px);    }  </style></head><body>  <div id="app">  </div></body></html>

虎课网https://www.wode007.com/sites/73267.html 设计坞https://www.wode007.com/sites/73738.html

所以,当需要计算外边距(margin),可以配合css3中的四则运算(calc)来使用

3. 使用建议

根据项目中的使用经验和w3c的建议,推荐将box-sizing属性设置为border-box。

* {  margin: 0;  padding: 0;}div {  box-sizing: border-box;}
本站仅提供存储服务,所有内容均由用户发布,如发现有害或侵权内容,请点击举报
打开APP,阅读全文并永久保存 查看更多类似文章
猜你喜欢
类似文章
【热】打开小程序,算一算2024你的财运
css的盒子模型属性有哪些?css盒子模型相关属性的介绍
CSS核心概念之盒子模型
盒模型的一些碎碎念
标准盒模型和怪异(ie)盒模型的对比
巧用CSS3的calc()宽度计算做响应模式布局
css菜鸡的自我救赎
更多类似文章 >>
生活服务
热点新闻
分享 收藏 导长图 关注 下载文章
绑定账号成功
后续可登录账号畅享VIP特权!
如果VIP功能使用有故障,
可点击这里联系客服!

联系客服