- CSS 教程
- CSS - 首页
- CSS - 路线图
- CSS - 简介
- CSS - 语法
- CSS - 选择器
- CSS - 引入
- CSS - 测量单位
- CSS - 颜色
- CSS - 背景
- CSS - 字体
- CSS - 文本
- CSS - 图片
- CSS - 链接
- CSS - 表格
- CSS - 边框
- CSS - 块级边框
- CSS - 内联边框
- CSS - 外边距
- CSS - 列表
- CSS - 内边距
- CSS - 光标
- CSS - 轮廓
- CSS - 尺寸
- CSS - 滚动条
- CSS - 内联块
- CSS - 下拉菜单
- CSS - 可见性
- CSS - 溢出
- CSS - 清除浮动
- CSS - 浮动
- CSS - 箭头
- CSS - 调整大小
- CSS - 引号
- CSS - 顺序
- CSS - 位置
- CSS - 连字符
- CSS - 悬停
- CSS - 显示
- CSS - 聚焦
- CSS - 缩放
- CSS - 转换
- CSS - 高度
- CSS - 连字符字符
- CSS - 宽度
- CSS - 不透明度
- CSS - Z 索引
- CSS - 底部
- CSS - 导航栏
- CSS - 覆盖层
- CSS - 表单
- CSS - 对齐
- CSS - 图标
- CSS - 图片库
- CSS - 注释
- CSS - 加载器
- CSS - 属性选择器
- CSS - 组合器
- CSS - 根
- CSS - 盒模型
- CSS - 计数器
- CSS - 剪辑
- CSS - 书写模式
- CSS - Unicode-bidi
- CSS - min-content
- CSS - 全部
- CSS - 内嵌
- CSS - 隔离
- CSS - 滚动溢出
- CSS - Justify Items
- CSS - Justify Self
- CSS - 制表符大小
- CSS - 指针事件
- CSS - Place Content
- CSS - Place Items
- CSS - Place Self
- CSS - 最大块尺寸
- CSS - 最小块尺寸
- CSS - 混合模式
- CSS - 最大内联尺寸
- CSS - 最小内联尺寸
- CSS - 偏移量
- CSS - 口音颜色
- CSS - 用户选择
- CSS 高级
- CSS - 网格
- CSS - 网格布局
- CSS - Flexbox
- CSS - 可见性
- CSS - 定位
- CSS - 图层
- CSS - 伪类
- CSS - 伪元素
- CSS - @规则
- CSS - 文本效果
- CSS - 分页媒体
- CSS - 打印
- CSS - 布局
- CSS - 验证
- CSS - 图片精灵
- CSS - 重要
- CSS - 数据类型
- CSS3 教程
- CSS3 - 教程
- CSS - 圆角
- CSS - 边框图片
- CSS - 多背景
- CSS - 颜色
- CSS - 渐变
- CSS - 盒阴影
- CSS - 盒装饰中断
- CSS - 光标颜色
- CSS - 文本阴影
- CSS - 文本
- CSS - 2D 转换
- CSS - 3D 转换
- CSS - 过渡
- CSS - 动画
- CSS - 多列
- CSS - 盒模型
- CSS - 工具提示
- CSS - 按钮
- CSS - 分页
- CSS - 变量
- CSS - 媒体查询
- CSS - 函数
- CSS - 数学函数
- CSS - 遮罩
- CSS - 形状
- CSS - 样式图像
- CSS - 特异性
- CSS - 自定义属性
- CSS 响应式
- CSS RWD - 简介
- CSS RWD - 视口
- CSS RWD - 网格视图
- CSS RWD - 媒体查询
- CSS RWD - 图片
- CSS RWD - 视频
- CSS RWD - 框架
- CSS 工具
- CSS - PX 到 EM 转换器
- CSS - 颜色选择器和动画
- CSS 资源
- CSS - 有用资源
- CSS - 讨论
CSS3 - 盒模型
CSS3 中的 box-sizing 属性用于定义元素的总宽度和高度是如何计算的。默认情况下,元素的宽度和高度包括其内容、内边距和边框。但是,使用 box-sizing 属性,您可以更改此行为,以包含或排除宽度和高度计算中的内边距和边框。
在旧版本的 CSS(CSS2)中,盒模型的工作方式使得元素看起来比传递给它的尺寸(宽度和高度)更大。
宽度 + 内边距 + 边框 = 元素盒的实际可见/渲染宽度
高度 + 内边距 + 边框 = 元素盒的实际可见/渲染高度
CSS3 盒模型属性
CSS box-sizing 属性可用于调整元素布局的行为。
可能的值
box-sizing CSS 属性可以有一个值,该值是一个关键字,可以是以下之一
content-box:这是默认值。当此值传递给 box-sizing 属性时,它将返回默认行为,其中内边距或/和边框将添加到元素的总宽度和高度中。
border-box:当此值传递给 box-sizing 属性时,它告诉浏览器调整传递给元素的内边距或边距值。这会导致内容区域缩小并吸收为元素指定的边框或/和内边距。它是 <table>、<select>、<button> 和 <input> 元素使用的默认样式。
padding-box 值不受任何浏览器支持,因此不能传递给 box-sizing 属性。
应用于
所有接受宽度或高度的 HTML 元素。
DOM 语法
object.style.boxSizing = "content-box | border-box";
示例
这是一个 CSS 属性 box-sizing: border-box 的示例
<html> <head> <style> .with-content-box { width: 200px; height: 100px; padding: 10px; border: 3px solid green; background-color: rgb(241, 234, 85); box-sizing: content-box; } .with-border-box { width: 200px; height: 100px; padding: 10px; border: 3px solid rgb(64, 10, 215); background-color: lightpink; box-sizing: border-box; } </style> </head> <body> <div class="with-content-box">CONTENT BOX</div><br /> <div class="with-border-box">BORDER BOX</div> </body> </html>
上面给出的示例清楚地显示了 box-sizing: border-box 和 box-sizing: content-box 属性值之间的区别。在这里,box-sizing: border-box 属性在计算总宽度和高度时忽略内边距值。而 box-sizing: content-box 属性值将内边距值包含在计算中。
为了获得流畅、灵活和直观的响应式设计,可以按以下方式设置 box-sizing: border-box 值
* { box-sizing: border-box; }
以上语法可能无法获得预期结果,因为它忽略了伪元素。因此,还有另一种语法包含用于重置的伪元素。
*, *:before, *:after { box-sizing: border-box; }
这种通用的盒模型大小方法将使使用 box-sizing: content-box | padding-box 变得困难。因此,还有另一种语法在这种情况下面可能更有用和更合适。
html { box-sizing: border-box; } *, *:before, *:after { box-sizing: inherit; }
这种通用的盒模型大小重置语法更有用,并为用户提供了更大的灵活性。
尽管每个当前浏览器都支持 box-sizing: border-box,无前缀;但某些旧版本的浏览器需要支持。为了提供该支持,您可能需要按以下方式使用前缀 -webkit 和 -moz
html { -webkit-box-sizing: border-box; -moz-box-sizing: border-box; box-sizing: border-box; } *, *:before, *:after { -webkit-box-sizing: inherit; -moz-box-sizing: inherit; box-sizing: inherit; }