如何实现侧边两栏宽度固定,中间栏宽度自适应的布局?——双飞翼布局、圣杯(Holy Grails)布局

简介: 如何实现侧边两栏宽度固定,中间栏宽度自适应的布局?——双飞翼布局、圣杯(Holy Grails)布局

勇气也许不能所向披靡,但胆怯根本无济于事。

希望你永远有勇气从头再来。

引用——圣杯(Holy Grails)布局&双飞翼布局

       圣杯布局的出现是来自由 Matthew Levine 在 2006 年写的一篇文章

       《In Search of the Holy Grail》,

       国内最早是淘宝UED的工程师(玉伯)对圣杯布局改进并传播开来,国内叫法是双飞翼布局 。

       双飞翼布局是针对圣杯局部优化的解决方案。主要是优化了圣杯布局中开启定位的问题。

 

       圣杯布局和双飞翼布局达到的效果基本相同,

       均是三栏布局,侧边两栏宽度固定,中间栏宽度自适应。

       主要的不同之处就是在防止中间部分被覆盖时,采取的解决办法不一样

       圣杯布局是在父元素上设置了padding-left和padding-right,在给左右两边的内容设置position为relative,通过左移和右移来使得左右两边的内容得以很好的展现,

       而双飞翼则是在center这个div中再加了一个div来放置内容,在给这个新的div设置margin-left和margin-right 。

浮动实现(兼容性好)

1.圣杯布局

 

<!DOCTYPE html>
<html>
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <meta http-equiv="X-UA-Compatible" content="ie=edge">
    <title>圣杯布局</title>
    <style type="text/css">
        body {
            min-width: 550px;
        }
        #header {
            text-align: center;
            background-color: #666;
        }
        #container {
            padding-left: 200px;
            padding-right: 150px;
        }
        #container .column {
            float: left;
            text-align: center;
        }
        #center {
            background-color: #D6D6D6;
            width: 100%;
        }
        #left {
            position: relative;
            background-color: #77BBDD;
            width: 200px;
            margin-left: -100%;
            right: 200px;
        }
        #right {
            background-color: #FF6633;
            width: 150px;
            margin-right: -150px;
        }
        #footer {
            background-color: #666;
        }
        /* 手写 clearfix */
        .clearfix:after {
            content: '';
            display: table;
            clear: both;
        }
    </style>
</head>
<body>
    <div id="header">#header</div>
    <div id="container" class="clearfix">
        <div id="center" class="column">#center</div>
        <div id="left" class="column">#left</div>
        <div id="right" class="column">#right</div>
    </div>
    <div id="footer">#footer</div>
</body>
</html>

(1)container设置padding属性,使width100%的center收缩,空出左右两栏的位置

(2)center、left、right等元素浮动起来,container没有设置高度,高度由内容撑开,所以container需要清除浮动

(3)给left元素设置margin-left:-100%; 它将向左移动父元素宽度的100%于是覆盖到center上

再给它设置相对定位,right:200px;使其继续向左移动,移动到合适位置。

(4)给right元素设置margin-right:-150px;使其宽度被忽略,视为0,将其放置在center后。

手写清除浮动

/* 手写 clearfix */
.clearfix:after {
     content: '';
    display: table;
    clear: both;
}

2.双飞翼布局

<!DOCTYPE html>
<html>
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <meta http-equiv="X-UA-Compatible" content="ie=edge">
    <title>双飞翼布局</title>
    <style type="text/css">
        body {
            min-width: 550px;
        }
        .column {
            float: left;
        }
        #center {
            width: 100%;
            height: 200px;
            background-color: #D6D6D6;
        }
        #center-wrap {
            margin: 0 200px 0 200px;
        }
        #left {
            width: 200px;
            height: 200px;
            background-color: #77BBDD;
            margin-left: -100%;
        }
        #right {
            width: 200px;
            height: 200px;
            background-color: #FF6633;
            margin-left: -200px;
        }
    </style>
</head>
<body>
    <div id="center" class="column">
        <div id="center-wrap">
            center
        </div>
    </div>
    <div id="left" class="column">
        left
    </div>
    <div id="right" class="column">
        right
    </div>
</body>
</html>

(1)给center-wrap设置margin,空出左右两栏的位置

(2)给left元素设置margin-left: -100%; 使其移动到左侧

(3)给right设置margin-left:-200px; 使其移动到右侧

 

flex实现(实现简单)

<!DOCTYPE html>
<html>
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <meta http-equiv="X-UA-Compatible" content="ie=edge">
    <title>flex实现圣杯布局</title>
    <style type="text/css">
        body {
            min-width: 550px;
        }
        #header {
            text-align: center;
            background-color: #666;
        }
        #container {
            display: flex;
        }
        #container .column {
            text-align: center;
        }
        #center {
            flex: 1;
            background-color: #D6D6D6;
        }
        #left {
            background-color: #77BBDD;
            width: 200px;
        }
        #right {
            background-color: #FF6633;
            width: 150px;
        }
        #footer {
            background-color: #666;
        }
    </style>
</head>
<body>
    <div id="header">#header</div>
    <div id="container">
        <div id="left" class="column">#left</div>
        <div id="center" class="column">#center</div>
        <div id="right" class="column">#right</div>
    </div>
    <div id="footer">#footer</div>
</body>
</html>

 

 

相关文章
|
4天前
|
人工智能 JSON 自然语言处理
让教学更智慧:用阿里云百炼工作流,自动生成中小学教材内容#小有可为#有温度的AI
通过可视化工作流编排,将大模型推理能力转化为标准化的教学内容生成引擎。教师只需输入教材标题和适用学段,即可自动获得结构完整、符合课程标准的章节内容,大幅降低备课门槛,助力教育资源均衡化。
446 122
|
6天前
|
人工智能 定位技术 SEO
我学 GEO 第 15 天:终于知道AI GEO该如何做?
我是暴走的莉莉酱,边旅行边研究AI GEO的数字游民。专注普通人如何提升“AI可见度”——让AI在回答用户问题时准确识别、理解并推荐你。不讲玄学,只做可测、可调、可持续的GEO实践。
430 125
|
8天前
|
机器学习/深度学习 人工智能 调度
🐴 HappyHorse 1.1 现已上线阿里云百炼!快来查收模型使用指南,现在调用享 6 折~
HappyHorse 1.1 是新一代视频生成大模型,全面升级动态表现力、角色一致性、指令遵循、视觉质感与音画协同能力。支持I2V/T2V/R2V三类生成,适配短剧、电商广告、品牌营销等场景,提供高质、流畅、可控的AI视频生产力。
718 5
🐴 HappyHorse 1.1 现已上线阿里云百炼!快来查收模型使用指南,现在调用享 6 折~
|
6天前
|
缓存 人工智能 运维
阿里云618百炼大模型Qwen3.7-Max功能、免费试用、订阅计费、配置接入详解
Qwen3.7-MAX是阿里云百炼平台推出的通义千问3.7系列旗舰大语言模型,专为智能体时代复杂任务打造,依托阿里云全域算力与自研技术,在逻辑推理、长文本处理、代码工程、长周期自主执行等领域达到行业顶尖水平。2026年618期间,该模型推出多重免费试用权益、按量计费5折、订阅套餐优惠等专属福利,覆盖个人开发者、团队与企业全场景需求,以下从核心功能、免费试用、订阅计费、配置接入四方面展开详细解析。
427 123
|
4天前
|
人工智能 自然语言处理 API
阿里云Token Plan团队版解析:功能、三档套餐与省钱订阅指南
阿里云百炼平台推出的Token Plan团队版,是面向企业与团队的AI大模型订阅服务,以Credits为统一计量单位,整合文本与图像生成模型,提供团队管理、数据安全、多工具兼容等核心能力,解决团队零散订阅AI服务的管理混乱、成本失控、数据安全等痛点。本文将从核心定位、套餐详情、计费规则、团队管理、工具兼容、便宜订阅技巧等方面,全面解析Token Plan团队版,帮助企业与团队高效、低成本地使用AI服务。
317 108
|
14天前
|
Linux 程序员 数据格式
【2026最新】Notepad++下载、安装和使用一篇搞定(附中文版安装包)
Notepad++ 是一款免费开源、轻量高效的 Windows 文本编辑器,支持 C/Python/HTML 等 80+ 语言语法高亮、代码折叠、正则替换、编码转换及插件扩展,专为程序员与文本处理用户打造,完美替代系统记事本。(239字)
|
5天前
|
存储 人工智能 数据可视化
别再手动复制 Skill 了:多 Agent 时代的 Skill 管理方案
多 Agent 场景下 Skill 的统一管理与同步。
274 125
|
8天前
|
存储 人工智能 监控
QoderWork完全指南:从入门到精通,把“AI实习生”变成你的全能工作搭档
阿里云2026年推出的桌面端AI工作助手QoderWork,不止聊天,更可动手干活:本地运行、安全可控,支持文件整理、数据分析、PPT生成、网页开发等;内置专家套件、多Agent协作与自定义Skills,让AI真正成为你身边的“AI实习生”。