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

相关推荐
月弦笙音1 天前
【包管理器】pnpm、npm、cnpm、yarn 深度对比
前端
吹水一流1 天前
微信小程序页面栈:从一个 Bug 讲到彻底搞懂
前端·微信小程序
j***82701 天前
【MyBatisPlus】MyBatisPlus介绍与使用
android·前端·后端
Python大数据分析@1 天前
我把pdfplumber整成了可以拖拉拽的web软件
前端·pdf
小华同学ai1 天前
终于有人帮你整理好了,火爆的“系统级提示词”支持ChatGPT、Claude、Gemini、xAI的
前端·后端·github
葡萄城技术团队1 天前
SpreadJS 电子表格权限管控设置指南
前端
HashTang1 天前
一个人就是一支队伍:从 Next.js 到显示器,聊聊我的“全栈续航”方案
前端·后端·程序员
朕的剑还未配妥1 天前
vue2中transition使用方法解析,包含底部弹窗示例、样式未生效踩坑记录
前端·vue.js
q***48411 天前
Redis Desktop Manager(Redis可视化工具)安装及使用详细教程
android·前端·后端
码上成长1 天前
组件库提速:Storybook + Chromatic + Visual Test 实战
前端·自动化