css【详解】—— 圣杯布局 vs 双飞翼布局 (含手写清除浮动 clearfix)

两者功能效果相同,实现方式不同

效果预览

在这里插入图片描述

  • 两侧宽度固定,中间宽度自适应(三栏布局)
  • 中间部分优先渲染
  • 允许三列中的任意一列成为最高列

圣杯布局

通过左右栏填充容器的左右 padding 实现,更多细节详见注释。

<!DOCTYPE html>
<html lang="en"><head><meta charset="UTF-8" /><meta name="viewport" content="width=device-width, initial-scale=1.0" /><title>css 圣杯布局</title><style>body {/* 清除浏览器默认样式 */margin: 0;/* 设置最小宽度 */min-width: 550px;}.header {background-color: gray;height: 40px;}.container {/* 圣杯布局 -- 通过 padding 实现 */padding-left: 200px;padding-right: 150px;}.center {/* center宽度自适应 */width: 100%;float: left;background-color: yellow;height: 100px;}.left {width: 200px;float: left;margin-left: -100%;position: relative;right: 200px;background-color: blue;height: 100px;}.right {width: 150px;float: left;margin-right: -150px;background-color: red;height: 100px;}.footer {/* 清除浮动 */clear: both;background-color: gray;height: 40px;}</style></head><body><div class="header">header</div><div class="container"><!-- center 置于 left 和 right 的上方,用于优先渲染页面主体内容 --><div class="center">center</div><div class="left">left</div><div class="right">right</div></div><div class="footer">footer</div></body>
</html>

双飞翼布局

通过左右栏填充主体内容的左右 margin 实现,更多细节详见注释。

<!DOCTYPE html>
<html lang="en"><head><meta charset="UTF-8" /><meta name="viewport" content="width=device-width, initial-scale=1.0" /><title>css 双飞翼布局</title><style>body {/* 清除浏览器默认样式 */margin: 0;/* 设置最小宽度 */min-width: 550px;}.header {background-color: gray;height: 40px;}.container {/* 自适应宽度 */width: 100%;/* 左浮动 */float: left;}.center {/* 双飞翼布局 -- 通过 margin 留白实现 */margin-left: 200px;margin-right: 150px;background-color: yellow;height: 100px;}.left {width: 200px;/* 左浮动 */float: left;/* 自身向左移动父元素(此处为body)宽度的 100% */margin-left: -100%;background-color: blue;height: 100px;}.right {width: 150px;/* 左浮动 */float: left;/* 自身向左移动 150px */margin-left: -150px;background-color: red;height: 100px;}.footer {/* 清除浮动 */clear: both;background-color: gray;height: 40px;}</style></head><body><div class="header">header</div><div class="container"><!-- center 置于 left 和 right 的上方,用于优先渲染页面主体内容 --><div class="center">center</div></div><!-- left 置于 container 外面 --><div class="left">left</div><!-- right 置于 container 外面 --><div class="right">right</div><div class="footer">footer</div></body>
</html>

手写清除浮动 clearfix

/* 手写 clearfix */
.clearfix:after {content: "";display: table;clear: both;
}
.clearfix {*zoom: 1; /* 兼容 IE 低版本 */
}

用在类似圣杯布局的容器上,footer 不再需要 clear: both;

<!DOCTYPE html>
<html lang="en"><head><meta charset="UTF-8" /><meta name="viewport" content="width=device-width, initial-scale=1.0" /><title>css 圣杯布局</title><style>body {/* 清除浏览器默认样式 */margin: 0;/* 设置最小宽度 */min-width: 550px;}.header {background-color: gray;height: 40px;}.container {/* 圣杯布局 -- 通过 padding 实现 */padding-left: 200px;padding-right: 150px;}.center {/* center宽度自适应 */width: 100%;float: left;background-color: yellow;height: 100px;}.left {width: 200px;float: left;margin-left: -100%;position: relative;right: 200px;background-color: blue;height: 100px;}.right {width: 150px;float: left;margin-right: -150px;background-color: red;height: 100px;}.footer {/* 清除浮动 *//* clear: both; */background-color: gray;height: 40px;}/* 手写 clearfix */.clearfix:after {content: "";display: table;clear: both;}.clearfix {*zoom: 1; /* 兼容 IE 低版本 */}</style></head><body><div class="header">header</div><div class="container clearfix"><!-- center 置于 left 和 right 的上方,用于优先渲染页面主体内容 --><div class="center">center</div><div class="left">left</div><div class="right">right</div></div><div class="footer">footer</div></body>
</html>

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/504642.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

零拷贝技术深入分析

一、零拷贝 在前面的文章“深浅拷贝、COW及零拷贝”中对零拷贝进行过分析&#xff0c;但没有举例子&#xff0c;也没有深入进行展开分析。本文将结合实际的例程对零拷贝进行更深入的分析和说明。 在传统的IO操作中&#xff0c;以文件通过网络传输为例 &#xff0c;一般会经历以…

挑战英伟达,需要另辟蹊径

Groq是近期AI芯片界的一个明星。原因是其号称比英伟达的GPU更快。3月2日&#xff0c;据报道&#xff0c;Groq收购了一家人工智能解决方案公司Definitive Intelligence。这是 Groq 在 2022 年收购高性能计算和人工智能基础设施解决方案公司 Maxeler Technologies 后的第二次收购…

【Kubernetes】k8s中容器之间、pod之间如何进行网络通信?

目录 PodKubernetes 网络模型同一Pod上的容器之间进行通信同一Node上的不同Pod之间进行通信不同Node上的Pod之间进行通信Service参考 Pod 首先来回顾一下Pod&#xff1a; Pod 是用于构建应用程序的最小可部署对象。单个 Pod 代表集群中正在运行的工作负载&#xff0c;并封装一…

【SpringBoot】测试单元使用多线程

&#x1f4dd;个人主页&#xff1a;五敷有你 &#x1f525;系列专栏&#xff1a;SpringBoot ⛺️稳重求进&#xff0c;晒太阳 问题产生 今天学习了乐观锁&#xff0c;但在测试单元执行多线程的时候出现了问题&#xff0c;多线程并没有直接结果 在控制台没有任何输出…

CSRF跨站请求伪造(一)

★★免责声明★★ 文章中涉及的程序(方法)可能带有攻击性&#xff0c;仅供安全研究与学习之用&#xff0c;读者将信息做其他用途&#xff0c;由Ta承担全部法律及连带责任&#xff0c;文章作者不承担任何法律及连带责任。 1、CSRF简介 CSRF&#xff0c;全称&#xff1a;Cross-S…

小程序配置服务器域名的操作步骤(入门级)

将详细列出小程序配置服务器域名的操作步骤&#xff1a; 服务器选购推荐&#xff1a;腾讯云轻量服务器 点击以下任一云产品链接&#xff0c;跳转后登录&#xff0c;自动享有所有云产品优惠权益&#xff1a; 经过笔者亲测&#xff0c;强烈推荐腾讯云轻量应用服务器作为游戏服…

计算机网络_2.1 物理层概述

2.1 物理层概述 一、物理层要实现的功能二、物理层接口特性 B站 深入浅出计算机网络 2.1物理层概述 一、物理层要实现的功能 物理层要实现的功能就是在各种传输媒体上传输比特0和1&#xff0c;进而给上面的数据链路层提供透明传输比特流的服务。 数据链路层“看不见”&#xff…

ssm172旅行社管理系统的设计与实现

** &#x1f345;点赞收藏关注 → 私信领取本源代码、数据库&#x1f345; 本人在Java毕业设计领域有多年的经验&#xff0c;陆续会更新更多优质的Java实战项目希望你能有所收获&#xff0c;少走一些弯路。&#x1f345;关注我不迷路&#x1f345;** 一 、设计说明 1.1 研究…

RDD算子介绍

1. RDD算子 RDD算子也叫RDD方法&#xff0c;主要分为两大类&#xff1a;转换和行动。转换&#xff0c;即一个RDD转换为另一个RDD&#xff0c;是功能的转换与补充&#xff0c;比如map&#xff0c;flatMap。行动&#xff0c;则是触发任务的执行&#xff0c;比如collect。所谓算子…

python自动化之项目架构搭建与思路讲解(第二天)

1.自动化测试的概念 自动化测试是指使用自动化工具和脚本来执行测试任务,以验证软件或系统的正确性和稳定性。它可以提高测试的效率和准确性,并节约时间和成本。 2.自动化脚本编写的思路 xmind文档如有需要,可在资源里自行下载 3.项目代码工程创建 lib :基本代码库包 …

像用Excel一样用Python:pandasGUI

文章目录 启动数据导入绘图 启动 众所周知&#xff0c;pandas是Python中著名的数据挖掘模块&#xff0c;以处理表格数据著称&#xff0c;并且具备一定的可视化能力。而pandasGUI则为pandas打造了一个友好的交互窗口&#xff0c;有了这个&#xff0c;就可以像使用Excel一样使用…

基于SpringBoot多模块项目引入其他模块时@Autowired无法注入

基于SpringBoot多模块项目引入其他模块时Autowired无法注入 一、问题描述1、解决方案 一、问题描述 启动Spring Boot项目时报 Could not autowire. No beans of ‘xxxxxxxx’ type found. 没有找到bean的实例&#xff0c;即spring没有实例化对象&#xff0c;也就无法根据配置文…