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

相关推荐
小圣贤君几秒前
Electron 桌面应用接入通义万相:文生图从 0 到 1 实战
前端·electron·ai写作·通义万相·ai生图·写作软件·小说封面
南风知我意9575 分钟前
【前端面试1】基础JS的面试题
前端·javascript·面试
wjhx15 分钟前
在Qt Design Studio中进行页面切换
前端·javascript·qt
钱多多先森16 分钟前
【Dify】使用 python 调用 Dify 的 API 服务,查看“知识检索”返回内容,用于前端溯源展示
开发语言·前端·python·dify
霍理迪17 分钟前
JS—数组
开发语言·前端·javascript
Surplusx17 分钟前
运用VS Code前端开发工具完成微博发布案例
前端·html
哪里不会点哪里.17 分钟前
Nginx 详解:高性能 Web 服务器与反向代理
服务器·前端·nginx
Ulyanov18 分钟前
超越平面:用impress.js打造智能多面棱柱演示器
开发语言·前端·javascript·平面
HWL567920 分钟前
vue抽离自定义指令的方法
前端·javascript·vue.js
2601_9495758620 分钟前
Flutter for OpenHarmony艺考真题题库+个人信息管理实现
java·前端·flutter