本篇文章给大家带来了关于css的相关知识,其中主要介绍了css盒子模型以及box-sizing属性的相关问题,box-sizing属性定义如何计算一个元素的总宽度和总高度,主要设置是否需要加上内边距(padding)和边框等,下面一起来看一下,希望对大家有帮助。

(学习视频分享:css视频教程、html视频教程)
盒模型定义及分类
CSS 基础框盒模型是 CSS 规范的一个模块,它定义了一种长方形的盒子, 包括它们各自的内边距(padding)与外边距(margin
),并根据视觉格式化模型来生成元素,对其进行布置、编排、布局。常被直译为盒子模型、盒模型或框模型。
盒模型有以下分类:
立即学习“前端免费学习笔记(深入)”;
标准定义:标准盒模型怪异模式盒模型元素类型块级盒子内联盒子行内块
标准定义划分
1. 标准盒子模型
宽度width = 内容宽度(content) + padding + border + margin
内容宽度仅仅只有content。如果设置一个元素的宽为100px,那么这个元素的内容区会有100px宽,并且任何边框和内边距的宽度都会被增加到最后绘制出来的元素宽度中。
2. 怪异模式盒子模型
宽度width = 内容宽度(content + padding + border) + margin
内容宽度包含了content、border、padding。如果将一个元素的width设为100px,那么这100px会包含它的border和padding,内容区的实际宽度是width减去(border + padding)的值。大多数情况下,这使得我们更容易地设定一个元素的宽高。
3. box-sizing属性
box-sizing属性有以下两个属性值。
box-sizing属性定义如何计算一个元素的总宽度和总高度,主要设置是否需要加上内边距(padding)和边框等。
例如,假如您需要并排放置两个带边框的框,可通过将 box-sizing 设置为 “border-box”。这样就可以让浏览器呈现出带有指定宽度和高度的框,并把边框和内边距放入框中。
默认情况下,元素的宽度(width) 和高度(height)计算方式如下:
width(宽度) + padding(内边距) + border(边框) = 元素实际宽度
height(高度) + padding(内边距) + border(边框) = 元素实际高度
1. content-box
默认值,使用标准盒子模型。
.contentBox { box-sizing: content-box; width: 350px; border: 10px solid black; padding: 0 10px;}
以上代码在浏览器中的渲染的实际宽度是390px。

2. border-box
使用怪异模式盒子模型。
.borderBox { box-sizing: border-box; width: 350px; border: 10px solid black; padding: 0 10px;}
以上代码在浏览器中的渲染的实际宽度就是350px。

示例如下:
123 div.container { width: 100%; border: 2px solid black;}div.box { box-sizing: border-box; width: 50%; border: 5px solid red; float: left;}这个 div 占据了左边部分这个 div 占据了右边部分
输出结果:

示例二:
* { box-sizing: border-box;}#example1 { width: 300px; padding: 40px; border: 15px solid blue;}#example2 { width: 300px; padding: 10px; border: 2px solid red;}通用的 box-sizing
使用 “box-sizing:border-box” 可以让前端开发人员减少很多工作。 上面 head 部分中的第一个样式确保所有元素都以这种更直观的方式调整大小。你设置的宽度就是实际的宽度,不需要考虑内边距和边框:
div 的完整宽度为 300px, 不需要考虑内边距和边框。
这个 div 的完整宽度也是 300px, 也不需要考虑内边距和边框。
输出结果:

元素类型划分
1. 块级盒子
一个被定义成块级的(block)盒子会表现出以下行为:
盒子可以占据父容器的所有可用空间每个盒子都会换行width和height属性可以发挥作用默认情况下h1-h6、p、p、section都处于block状态
2. 内联盒子
一个被定义成内联的(inline)盒子会表现出以下行为:
盒子不会产生换行width和height属性将不起作用默认情况下用做链接的a元素、span、em以及strong都处于inline状态
3. 特殊的行内块
如果不希望一个项切换到新行,但希望它可以设定宽度和高度,此时我们可以将该元素设置为inline-block。
4. 元素类型切换
display属性值块级盒子block内联盒子inline行内块inline-block
4. 盒模型属性设置
1. margin和padding
1个值:四个方向2个值:上下、左右3个值:上、左右、下4个值:上、右、下、左
2. border值
border: 10px double red;
10px、双实线、红色边框。
(学习视频分享:css视频教程、html视频教程)
以上就是介绍下CSS盒子模型以及box-sizing属性的详细内容,更多请关注创想鸟其它相关文章!
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/1624491.html
微信扫一扫
支付宝扫一扫