从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开发干货。

相关推荐
盏茶作酒2912 分钟前
打造自己的组件库(一)宏函数解析
前端·vue.js
山有木兮木有枝_32 分钟前
JavaScript 设计模式--单例模式
前端·javascript·代码规范
一大树1 小时前
Vue3 开发必备:20 个实用技巧
前端·vue.js
颜渊呐1 小时前
uniapp中APPwebview与网页的双向通信
前端·uni-app
10年前端老司机1 小时前
React 受控组件和非受控组件区别和使用场景
前端·javascript·react.js
夏晚星1 小时前
vue实现微信聊天emoji表情
前端·javascript
停止重构1 小时前
【方案】前端UI布局的绝技,响应式布局,多端适配
前端·网页布局·响应式布局·grid布局·网页适配多端
極光未晚1 小时前
TypeScript在前端项目中的那些事儿:不止于类型的守护者
前端·javascript·typescript
ze_juejin1 小时前
Vue3 + Vite + Ant Design Vue + Axios + Pinia 脚手架搭建
前端·vue.js
Rrvive1 小时前
原型与原型链到底是什么?
javascript