从0到1掌握盒子模型:精准控制网页布局的秘诀

引言

html页面中任何元素都是一个盒子(box)。学好css的基础是理解盒模型的工作原理。也是爬虫选择器入门的基础

盒子模型基础解剖

内容和大小

盒子的大小可以有两种控制方式:

  • extrinsic sizing : 显式设置盒子的widthheight为固定尺寸,例如设置widthheight为400px、600px,那么盒子的大小就固定了。
  • intrinsic sizing : 不设置盒子的大小,或者设置盒子的大小为非固定尺寸,例如设置widthheight属性值为min-content或者max-content, 此时盒子的大小由浏览器决定,浏览器会根据内容自动调整盒子的大小。

盒子的四层结构

css 复制代码
/* 可视化盒子模型 */
.element {
  width: 300px;         /* 内容宽度 */
  padding: 20px;        /* 内边距(内容与边框的距离) */
  border: 3px solid #f06; /* 边框 */
  margin: 30px;         /* 外边距(边框外部的宽带) */
  background: #f0f8ff;  /* 背景延伸到边框 */
}

box-sizing属性

box-sizing定义了如何去计算一个元素的高度和宽度。当你设置了元素的widthheight尺寸时,默认情况下设置的是content区域的尺寸,这意味着盒子最终的大小为会加上borderSize和paddingSize,而不是你设置的尺寸。我们可以设置box-sizingborder-box, 覆盖这一默认行为,此时我们设置的widthheight尺寸就是盒子最终的尺寸(包括边框和内边距)。

box-sizing可以设置如下两种值:

  • content-box: 是默认值。如果你设置一个元素的宽为100px,那么这个元素的内容区会有100px 宽,并且任何边框和内边距的宽度都会被增加到最后绘制出来的元素宽度中。
  • border-box: 你想要设置的边框和内边距的值是包含在width内的。也就是说,如果你将一个元素的width设为100px,那么这100px会包含它的border和padding,内容区的实际宽度是width减去(border + padding)的值。大多数情况下,这使得我们更容易地设定一个元素的宽高。

高级布局实战技巧举例

精准尺寸计算

css 复制代码
/* 完美等宽三栏布局 */
.grid {
  display: flex;
}

.column {
  flex: 1;                   /* 基础比例 */
  padding: 15px;
  margin: 0 10px;
  border: 1px solid #ddd;
  
  /* 精确宽度 = 100% - margin*2 - padding*2 - border*2 */
  box-sizing: border-box;    /* 关键! */
}

负margin的黑科技

css 复制代码
/* 经典圣杯布局 */
.container {
  padding: 0 200px; /* 左右预留空间 */
}

.main {
  width: 100%;
  float: left;
}

.left {
  width: 200px;
  float: left;
  margin-left: -100%; /* 关键! */
  position: relative;
  left: -200px;
}

.right {
  width: 200px;
  float: left;
  margin-left: -200px; 
  position: relative;
  right: -200px;
}

总结

如果你喜欢本教程,记得点赞+收藏!关注我获取更多JavaScript开发干货。

相关推荐
前端那点事4 小时前
Vue3 script setup 语法糖最全教程!零基础吃透+项目落地+面试满分
前端·vue.js
ConardLi4 小时前
Harness 实践:让 Agent 全自动制作知识讲解视频
前端·人工智能·后端
费曼学习法4 小时前
React Hooks 源码级揭秘:为什么必须按顺序调用?
javascript·react.js
努力干饭中4 小时前
Vibe Coding 第二弹:做一个 Canvas K线图
前端·canvas·vibecoding
卷帘依旧4 小时前
Vue 响应式原理:Object.defineProperty vs Proxy 深度对比
前端·vue.js
yqcoder4 小时前
原生 AJAX 揭秘:如何使用 XHR 发起请求
前端·ajax·okhttp
ZC跨境爬虫4 小时前
跟着 MDN 学 HTML day_34:(深入XML 中的 CDATASection 接口)
xml·前端·html·html5·媒体
之歆4 小时前
DAY_20JavaScript 条件语句与循环结构深度学习(二)
前端·javascript
山北雨夜漫步4 小时前
LangGraph
java·前端·算法
漓漾li5 小时前
每日面试题-前端
前端·react.js·面试