圣杯布局和双飞翼布局

圣杯布局(Holy Grail Layout)和双飞翼布局(Double Wings Layout)是两种常见的多列布局技术,用于实现一个固定宽度的主内容区域,以及左右两侧可变宽度的侧边栏。这两种布局都希望能够实现以下效果:

  • 主内容区域垂直排在页面最前面,占据剩余的宽度。
  • 左右两侧的侧边栏分别位于主内容区域的左右两侧,宽度可以自适应或指定。

下面是对两种布局的简要介绍:

1. 圣杯布局:

圣杯布局使用相对定位和负边距来实现侧边栏的定位。HTML结构如下:

html 复制代码
<div class="container">
  <div class="sidebar sidebar-left"></div>
  <div class="content"></div>
  <div class="sidebar sidebar-right"></div>
</div>

CSS样式如下:

css 复制代码
.container {
  padding: 0 200px; /* 左右侧边栏的宽度 */
}

.sidebar {
  float: left;
  width: 200px; /* 侧边栏的宽度 */
}

.sidebar-left {
  margin-left: -100%;
  position: relative;
  right: 200px; /* 右侧边栏的宽度 */
}

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

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

2. 双飞翼布局:

双飞翼布局通过使用嵌套的<div>来实现侧边栏的定位,以及使用负外边距将主内容区域撑开。HTML结构如下:

html 复制代码
<div class="container">
  <div class="content">
    <!-- 主内容 -->
  </div>
</div>
<div class="sidebar sidebar-left"></div>
<div class="sidebar sidebar-right"></div>

CSS样式如下:

css 复制代码
.container {
  padding: 0 200px; /* 左右侧边栏的宽度 */
}

.content {
  margin: 0 200px; /* 左右侧边栏的宽度 */
}

.sidebar {
  float: left;
  width: 200px; /* 侧边栏的宽度 */
}
相关推荐
卷帘依旧20 分钟前
WebSocket 比 SSE 复杂在哪里
javascript
不吃土豆的马铃薯33 分钟前
4.SGI STL 二级空间配置器 allocate 与_S_refill 源码解析
c语言·开发语言·c++·dreamweaver·内存池
卷帘依旧41 分钟前
SSE(Server-Sent Events)完全指南
前端
码云之上42 分钟前
万星入坞:我们如何用三层插件体系干掉巨石应用
前端·架构·前端框架
kyriewen1 小时前
一口气讲清楚 Monorepo、Turborepo、pnpm、Changesets 到底是什么?
前端·架构·前端工程化
码界筑梦坊1 小时前
120-基于Python的食品营养特征数据可视化分析系统
开发语言·python·信息可视化·数据分析·毕业设计·echarts·fastapi
logo_281 小时前
Xpath语法规则的学习和使用
javascript·python·xpath·xpath语法
lsx2024061 小时前
《Foundation 模态框》
开发语言
fufu03111 小时前
vscode配置C/C++环境,用GDB调试简单程序分享
开发语言·c++
快乐江湖2 小时前
「层层包装」—— 装饰器模式
开发语言·python·装饰器模式