【css】回想下经典的布局

看到这张图相信大多数人都很熟悉,这曾经是一种经典的布局方式,一道经典的面试题,一般形如"实现一个布局,左右固定宽度,中间自适应"。随着岁月的流转,时光的交替(颇有一种“天下风云出我辈,一入江湖岁月催”的感慨,哈哈),它一步步逐渐退出了历史舞台,不过在经典,总是有它经典的含义在里面,今天笔者就尝试站在自己认知范围内,重新诠释了下经典,实现的手段则是用了各种可能的方式实现这一经典布局:
1、基于FL FR的实现
.layout1 {
height: 100px;
overflow: hidden
}
.layout1 .l {
height: 100%;
width: 100px;
float: left;
}
.layout1 .m {
height: 100%;
margin: 0 200px 0 100px;
}
.layout1 .r {
height: 100%;
width: 200px;
float: right;
}
<div class='layout1'>
<div class='l'></div>
<div class='r'></div>
<div class='m'>layout1</div>
</div>
图中的第一个行就是基于此方式实现的,原理很简单,利用浮动元素脱离文档流的特性,左边的左浮动,右边的有浮动,简单粗暴。
2、圣杯布局
.layout2 {
height: 100px;
overflow: hidden;
padding: 0 200px 0 100px;
}
.layout2 .m {
float: left;
width: 100%;
height: 100%;
}
.layout2 .l {
float: left;
width: 100px;
margin-left: -100%;
position: relative;
left: -100px;
}
.layout2 .r {
width: 200px;
margin-left: -200px;
float: left;
position: relative;
right: -200px;
}
<div class='layout2'>
<div class='m'>layout2</div>
<div class='l'></div>
<div class='r'></div>
</div>
为了保证dom元素的尽快展示,而将最重要的元素放在最前解析,优化用户体验,使用负margin和相对定位调整左右元素位置,使用大容器的padding作为调整空间的hack,十分经典的手法;
3、双飞翼布局
.layout3 {
height: 100px;
overflow: hidden;
}
.layout3 .m-wrap {
width: 100%;
float: left;
height: 100%;
}
.layout3 .m {
margin: 0 200px 0 100px;
}
.layout3 .l {
float: left;
width: 100px;
margin-left: -100%;
}
.layout3 .r {
float: left;
width: 200px;
margin-left: -200px;
}
<div class='layout3'>
<div class='m-wrap'>
<div class='m'>layout3</div>
</div>
<div class='l'></div>
<div class='r'></div>
</div>
与之前的方式基本一致,唯一的不同是添加了一个标签,而没有依赖根容器做hack。
1、2、3三种实现都是基于BFC(Block Formatting Contexts)规则的,直译作“块级格式化上下文”,它会在页面上隔离出一个渲染区域,容器里的子元素并不会在布局上影响到外面的元素。如何产生BFC呢?它需要满足以下规则:
- float 除了none以外的值
- overflow 除了visible 以外的值(hidden,auto,scroll )
- display (table-cell,table-caption,inline-block, flex, inline-flex)
- position值为(absolute,fixed)
- fieldset元素
虽然概念可能有些陌生,其实我们在解决边界重叠(父子兄弟元素的margin重合)问题会经常通过触发BFC的方式来解决,另外,清除浮动也是这个原理,不过这些并不是本文的重点,那么让我们继续,看看其他的实现方式。
4、flex实现
.layout4 {
display: flex;
height: 100px;
}
.layout4 .l {
flex: 0 0 auto;
width: 100px;
}
.layout4 .m {
flex: 1 1 auto;
}
.layout4 .r {
flex: 0 0 auto;
width: 200px;
}
<div class='layout4'>
<div class='l'></div>
<div class='m'>layout4</div>
<div class='r'></div>
</div>
实现十分简单,利用伸缩盒模型的特性,只需要开启中间元素的flex-grow(为了保证缩小时的正常显示笔者还开启了flex-shrink)就能个很轻易的实现这种布局,不过为了美观,笔者并没有贴上兼容性的代码。当然,想实现之前那种优先渲染的方式flex也是支持的:
.layout4 {
display: flex;
height: 100px;
}
.layout4 .l {
flex: 0 0 auto;
width: 100px;
}
.layout4 .m {
order: 1;
flex: 1 1 auto;
}
.layout4 .r {
order: 2;
flex: 0 0 auto;
width: 200px;
}
<div class='layout4'>
<div class='m'>layout4</div>
<div class='l'></div>
<div class='r'></div>
</div>
原理也很简单,使用order属性就可以轻松实现了。
flex实现与之前不同,基于的是FFC(Flex Formatting Contexts)规则,即“自适应格式化上下文”。与BFC略显复杂的触发规则不同,只要有元素满足display为flex或inline-flex,则会应用这套规则。
想来所有方式似乎都已穷举?其实不然,还有去年刚出台的新规则css-grid可以一试,于是
5、css grid
.layout5 {
height: 100px;
display: grid;
grid-template-columns: 100px 1fr 200px;
}
<div class='layout5'>
<div class='l'></div>
<div class='m'>layout5</div>
<div class='r'></div>
</div>
可以看到,基于css grid的实现是最为便捷的,基于不需要操作grid item,只需要设置容器就可以轻易实现,不过由于是新事物,所以兼容性比较差。
对应grid也有其对应的规范叫作“GFC”(Grid layout Formatting Contexts),即“网格布局格式化上下文”,与flex类似,只需要设置disply为grid即可开启,但是请注意,它与我们通常理解的table(相信大家心里都有很多想关于table的吐槽)布局并不一致,正如上面例子中的,这种css grid布局提供了很多方便的属性给我们用于绘制网格。
除了以上BFC、FFC、GFC,常见的还有一个IFC(Inline Formatting Contexts),即“内联格式化上下文”,display为inline、inline-block、inline-table的元素,在IFC中,行内元素是一个接一个排列的,起点是容器的顶部,虽然横向的margin、padding、border得以保留,但是垂直方向上则会以不同的方式对齐,通常额可以设置vertical-align来控制其对齐方式。值得注意一点的是虽然行内元素内部可以形成一个BFC,而对外它则会形成IFC。
话说回来,这确实是一种经典的布局,几乎所有新的布局方式都是很友好的在支持它,从蛮荒时代的要使用各种hack手段来实现,到现代的轻而易举的实现,也足见其在css发展中的重要地位,现在想来也确实,css3之前的css更多的像是一种工具式的语言,它没有任何优雅的特性,了无生趣,而到了css3时代,无论从性能上的优化,工程上的提高,都是可圈可点的。
当然,类似经典的实现在css中还有很多,例如各种垂直居中的方法,与js更新换代的方式不同,旧的技术不断被新技术替换,而在css领域,这种返古现象却经常发生,当然也和浏览器厂商、各个平台,复杂的兼容性场景有关,但是其中蕴含的思想就像jQuery那种设计理念,却不会随着岁月的流逝而过时,反而在特定的时间上,更是弥足珍贵的。
【css】回想下经典的布局的更多相关文章
- 从零开始,搭建博客系统MVC5+EF6搭建框架(4)下,前后台布局实现、发布博客以及展示。
一.博客系统进度回顾 目前已经完成了,前台展示,以及后台发布的功能,最近都在做这个,其实我在国庆的时候就可以弄完的,但是每天自己弄,突然最后国庆2天,连电脑都不想碰,所以就一直拖着,上一篇写了前端实现 ...
- CSS样式表与格式布局
样式表 CSS(Cascading Style Sheets 层叠样式表),作用是美化HTML网页. 内联样式表: 例:<p style="font-size:10px;" ...
- CSS+JS下拉菜单和纯CSS下拉菜单
下拉菜单 (思路:先把二级定位到屏幕外,鼠标悬停重新定位回来:另一个就是ul浮动,li也浮动) 下拉菜单的一般思路就是把子导航嵌套在无序列表中,把列表定位到屏幕之外,当鼠标悬停在其父列表项上时,重新定 ...
- 如何使用Flexbox和CSS Grid,实现高效布局
CSS 浮动属性一直是网站上排列元素的主要方法之一,但是当实现复杂布局时,这种方法不总是那么理想.幸运的是,在现代网页设计时代,使用 Flexbox 和 CSS Grid 来对齐元素,变得相对容易起来 ...
- 精通CSS+DIV网页样式与布局--图片效果
提到图片效果,小伙伴们可能会想到美图秀秀,ps等,这些软件都是款非常不错的照片处理软件,包括常用的:黑白,增强,高斯,高对比,夜视,老照片和铅笔画等等.不管你是否是专业的 照片拍摄人员,我们都可以通过 ...
- 精通CSS+DIV网页样式与布局--初探CSS
CSS英文名Cascading Style Sheet,中文名字叫层叠样式表,是用于控制页面样式并允许将样式信息与网页内容分离的一种标记性语言,DIV+CSS是WEB设计标准,它是一种网页的布局方法. ...
- 如何使用 Flexbox 和 CSS Grid,实现高效布局
CSS 浮动属性一直是网站上排列元素的主要方法之一,但是当实现复杂布局时,这种方法不总是那么理想.幸运的是,在现代网页设计时代,使用 Flexbox 和 CSS Grid 来对齐元素,变得相对容易起来 ...
- 纯CSS实现移动端常见布局——高度和宽度挂钩的秘密
纯CSS实现移动端常见布局--高度和宽度挂钩的秘密 不踩坑不回头.之前我在一个项目中大量使用css3的calc计算属性.写代码的时候真心不要太爽啊-可是在项目上线之后,才让我崩溃了,原因非常easy, ...
- 87.CSS Flex 弹性盒模型布局教程(共用的css在48篇文章gird)
CSS Flex 弹性盒模型布局教程 Flex 是 Flexible Box 的缩写,意为"弹性布局",用来为盒状模型提供最大的灵活性. flex布局就是给任何一个容器添加 dis ...
随机推荐
- node.js 读取文件--createReadStream
createReadStream 是fs模块里面读流的一个方法 这个方法基于fs模块的,所以我们先要引进fs模块 let fs=require("fs"); createReadS ...
- [NOIP2006] 提高组 洛谷P1064 金明的预算方案
题目描述 金明今天很开心,家里购置的新房就要领钥匙了,新房里有一间金明自己专用的很宽敞的房间.更让他高兴的是,妈妈昨天对他说:“你的房间需要购买哪些物品,怎么布置,你说了算,只要不超过N元钱就行”.今 ...
- GDAL源码编译
转自阿Fai, GDAL源码编译 在这里,我使用源码编译出C#可以使用的dll静态文件. 一.简单的编译 1.简单的认识 首先进入GDAL的源代码目录,可以看到有几个sln为后缀的文件名,比如make ...
- WebLogic11g-创建域(Domain)及基本配置
最近看到经常有人提问weblogic相关问题,所以闲暇之际写几篇博文(基于weblogic11),仅供大家参考. 具体weblogic的介绍以及安装,这里就不赘述了. 以域的创建开篇,虽然简单,但 ...
- Nginx系列(五)--nginx+tomcat实现负载均衡
Nginx占有内存少,并发能力强,其实Nginx的并发能力确实在同类型的网页伺服器中表现较好.眼下中国大陆使用Nginx站点用户有:新浪,网易,腾讯等. 本文主要是基于Nginx搭建tomcat集群. ...
- 面试题之strcpy/strlen/strcat/strcmp的实现
阿里的电面要我用C/C++实现一个字符串拷贝的函数,虽然以前写过 strcpy 的函数实现,但时间过去很久了,再加上有点紧张,突然就措手不及了.最后写是写出来了,但没考虑异常的情况,面试官好像很不满意 ...
- Mysql-SQL优化-统计某种类型的个数
有时我们想统计某种类型有多少个,会用这个SQL. 全表扫描之余,还要filesort.耗时1.34秒. mysql> select country,count(*) from t1 group ...
- c# Http下载
1.首先是服务器上发布资源,如果资源时自定义格式,比如 .zidingyi结尾的后缀文件,需要在MIME类型上添加处理方式 需要注意的是.net里面要设置 System.Net.ServicePoin ...
- Hihocoder #1479 : 三等分 树形DP
三等分 描述 小Hi最近参加了一场比赛,这场比赛中小Hi被要求将一棵树拆成3份,使得每一份中所有节点的权值和相等. 比赛结束后,小Hi发现虽然大家得到的树几乎一模一样,但是每个人的方法都有所不同.于 ...
- java SocketChannel and ServerSocketChannel
1 SocketChannel 1.1 打开一个SocketChannel SocketChannel socketChannel = SocketChannel.open(); socketChan ...