深入了解css3 border-sizing属性

深入了解css3 border-sizing属性

推荐:css视频教程

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属性包括内容,内边距和边框,但不包括外边距。

立即学习“前端免费学习笔记(深入)”;

计算公式:

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

height = border + padding + 内容高度

2. 考虑盒子模型的margin

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

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

实现如下效果图:

1.png

代码:css视频教程

nbsp;html>        yuanxin.me      *{      margin: 0;      padding: 0;    }    #app {      box-sizing: border-box; /* 指定计算方式 */      margin: 10px; /* 外边距干扰 */      /* 利用 css3 的 calc */      width: calc(100vw - 2*10px);      height: calc(100vh - 2*10px);    }    
  

登录后复制

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

3. 使用建议

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

* {  margin: 0;  padding: 0;}div {  box-sizing: border-box;}

登录后复制

更多编程相关知识,请访问:css视频教程!!

以上就是深入了解css3 border-sizing属性的详细内容,更多请关注【创想鸟】其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至253000106@qq.com举报,一经查实,本站将立刻删除。

发布者:PHP中文网,转转请注明出处:https://www.chuangxiangniao.com/p/2881907.html

(0)
上一篇 2025年3月10日 20:06:57
下一篇 2025年3月3日 05:53:17

AD推荐 黄金广告位招租... 更多推荐

相关推荐

  • 引入的css图片怎么加载不了

    加载不了的原因:1、css代码写错了;2、css图片的引入地址不对;3、包含css图片的html容器(例div)的宽度和高度没有设置固定值,css图片不会撑开元素容器;4、HTML代码书写不规范;5、引入css图片的元素不具备块属性。 本教…

    2025年3月10日
    200
  • css怎么让背景图片不重复

    在css中,可以使用background-repeat属性来让背景图片不重复,该属性可以设置背景图片是否重复以及如何重复;只需给背景图片设置“background-repeat:no-repeat;”样式即可让背景图片不重复。 本教程操作环…

    2025年3月10日 编程技术
    200
  • css行内样式为什么尽量不要使用

    css行内样式是直接将样式属性写在开始标签style属性中,多个元素难以共享样式,不利于代码复用;且HTML和CSS代码混杂,结构样式没有分离,不利于程序员和搜索引擎阅读,不利于后期维护。 本教程操作环境:windows7系统、css3版本…

    2025年3月10日
    200
  • css怎么去掉div间距

    css去掉div间距的方法:1、通过margin和padding属性去除div内部间距和外部间距;2、设置父级元素“font-size”为0,然后重新设置div的“font-size”即可正常去除div之间的间距。 本教程操作环境:Wind…

    2025年3月10日
    200
  • css怎么将文字底对齐

    css将文字底对齐的方法:首先创建一个HTML示例文件;然后定义一个div块;最后通过设置css样式为“display:table-cell;vertical-align:bottom;”来实现将文字底对齐即可。 本教程操作环境:Windo…

    2025年3月10日
    200
  • css超链接的底色如何设置

    css超链接底色的设置方法:首先创建一个HTML示例文件;然后通过对超链接添加css样式属性为“a:link {color:#FF0000;}a:visited {color:#00FF00;}”来设置底色即可。 本教程操作环境:Windo…

    2025年3月10日
    200
  • css中词语间隔怎么设置

    在css中可以通过“word-spacing”属性来设置单词的间距,其使用语法如“p{word-spacing:30px;}”,该属性可以使单词间距变小,也可以变大。 本教程操作环境:Windows7系统、HTML5&&CS…

    2025年3月10日
    200
  • css div不随滚动条移动的实现方法

    css div不随滚动条移动的实现方法:首先创建一个示例文件;然后通过给div设置css属性样式为“position:fixed;”即可固定div不随滚动条移动。 本教程操作环境:Windows7系统、HTML5&&CSS3…

    2025年3月10日
    200
  • css子类选择器是什么

    在css中,类选择器是值“E > F”选择器,用于匹配E元素的所有一级子元素F;子类选择器仅仅指的是父元素的直接后代,大家可以理解为仅作用于第一代子元素,通过“>”进行选择。 本文操作环境:windows10系统、css 3、t…

    2025年3月10日
    200
  • css 什么是相对长度单位

    在css中,相对长度单位是根据与其他事物的关系来度量的长度单位,是没有固定值的。所度量的实际距离,可能会因为不在其控制之下的其他因素而改变,如屏幕分辨率、可视区域的宽高等等;并且,对于某些相对单位,其大小会因使用该单位的元素的不同而不同。 …

    2025年3月10日
    200

发表回复

登录后才能评论