圣杯布局和双飞翼布局

圣杯布局(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; /* 侧边栏的宽度 */
}
相关推荐
zhaoyin19943 分钟前
Fiddler弱网实战
前端·测试工具·fiddler
yufuu987 分钟前
并行算法在STL中的应用
开发语言·c++·算法
charlie11451419121 分钟前
嵌入式C++教程——ETL(Embedded Template Library)
开发语言·c++·笔记·学习·嵌入式·etl
陳103021 分钟前
C++:AVL树的模拟实现
开发语言·c++
zfoo-framework42 分钟前
docker desktop
开发语言
m0_736919101 小时前
C++中的享元模式变体
开发语言·c++·算法
集芯微电科技有限公司1 小时前
15V/2A同步开关型降压单节/双节锂电池充电管理IC支持输入适配器 DPM 功能
c语言·开发语言·stm32·单片机·嵌入式硬件·电脑
换日线°1 小时前
前端炫酷展开效果
前端·javascript·vue
菩提树下的凡夫2 小时前
Python 环境管理工具
开发语言·python
索荣荣2 小时前
JavaToken实战指南:从原理到应用
开发语言·python