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

相关推荐
欣然~几秒前
FachuanHybridSystem 项目 Windows 完整安装启动文档
前端
anyup2 分钟前
uView Pro 的主题系统有多强大?3 分钟设计 uni-app 企业级 UI 主题
前端·vue.js·uni-app
BUG_Jia5 分钟前
Vue 3 组件封装与使用:保姆级教程
前端·javascript·vue.js
奇舞精选8 分钟前
观察 AIRI 源码:一个 Agent 系统如何处理入口、扩展与执行闭环
前端·openai
思成Codes11 分钟前
从本质看:Vue3 为什么运用 LIS 算法
javascript·vue.js
江湖行骗老中医20 分钟前
Pinia 是 Vue 的专属状态管理库
前端·javascript·vue.js
用户693717500138421 分钟前
Android 开发,别只钻技术一亩三分地,也该学点“广度”了
android·前端·后端
郑鱼咚22 分钟前
别再神化Spec了,它可能只是AI Coding的临时补丁
前端
张元清26 分钟前
React 鼠标追踪与交互效果实战
前端·javascript·面试
MinterFusion27 分钟前
HTML DOM元素的定位问题
前端·css·html