css盒模型

元素宽度的问题

当给一个元素设置宽或高的时候,指定的是内容的宽或高,所有内边距、边框、外边距都是追加到该宽度上的。这种行为会让一个宽 300px、内边距 10px、边框 1px 的元素渲染出来宽 322px(宽度加左右内边距再加左右边框)。如果这些值使用不同的单位,情况就会更复杂。

调整盒模型

box-sizing 的默认值为 content-box,这意味任何指定的宽或高都只会设置内容盒子的

大小。将 box-sizing 设置为 border-box 后, height 和 width 属性会设置内容、内边距以

及边框的大小总和,这刚好符合示例的要求。

全局设置box-sizing,给页面上所有元素和伪元素设置 border-box

css 复制代码
:root {
box-sizing: border-box;
}
*,
::before,
::after {
box-sizing: inherit;
}

盒模型通常不会被继承,但是使用 inherit 关键字可以强制继承。如下述代码所示,可以在必要时选中第三方组件的顶级容器,将其恢复为 content-box。这样组件的内部元素会继承该盒模型。

css 复制代码
.third-party-component {
box-sizing: content-box;
}
元素高度问题

等高列用display: table或Flexbox

相关推荐
oo121383 分钟前
里程碑5 - 完成框架 npm 包抽象封装并发布
前端·npm
达拉3 分钟前
我花了三天用AI写了个上一代前端构建工具
前端·前端工程化
bysking7 分钟前
【31-Ai-Agent】ai-agent的核心实现细节-bysking
前端
从文处安11 分钟前
「前端何去何从」(React教程)React 状态管理:从局部 State 到可扩展架构
前端·react.js
一拳不是超人15 分钟前
Three.js一起学-如何通过官方例子高效学习 Three.js?手把手带你“抄”出一个3D动画
前端·webgl·three.js
椰子皮啊18 分钟前
400行Node.js搞定mediasoup信令转换:一次跨语言"表白"实录
前端·架构
果然_27 分钟前
告别混淆!Git 多账号按域名/目录自动切换身份的终极指南
前端
Wect31 分钟前
React Scheduler & Lane 详解
前端·react.js·面试
myNameGL31 分钟前
ArkTs核心语法
前端·javascript·vue.js
重庆穿山甲40 分钟前
从零到精通:OpenClaw完整生命周期指南
前端·后端·架构