三栏式布局(所谓的圣杯和双飞翼)_html/css_WEB-ITnose
内容导读
互联网集市收集整理的这篇技术教程文章主要介绍了三栏式布局(所谓的圣杯和双飞翼)_html/css_WEB-ITnose,小编现在分享给大家,供广大互联网技能从业者学习和参考。文章包含4270字,纯文字阅读大概需要7分钟。
内容图文
× 目录 [1]float [2]absolute [3]flex [4]总结前面的话
常常听说圣杯布局和双飞翼布局,以为是两个很高级的语汇。但实际上,他们只是三栏式布局的两种布局方法而已。本文将介绍三栏式布局的3种思路
思路一: float
【1】圣杯布局
圣杯布局使用float、负margin和relative,不需要添加额外标签。.main元素设置padding,为两侧定宽元素留出位置。内容元素设置100%宽度,占据中间位置。而两侧定宽元素通过设置负margin和relative的偏移属性配合,到达相应位置
缺点: 并没有实现等高布局;使用了相对定位,扩展性不好
top
main
main
left
right
bottom
【2】双飞翼布局
双飞翼布局在圣杯布局的基础上,通过为.main元素外添加一层div结构,不使用相对定位。在.main元素上设置margin。两侧的定宽列通过负margin来占据.main元素的margin区域
缺点: 并没有实现等高布局,增加了html结构
top
main
main
left
right
bottom
【3】float + box-sizing + background-clip
.main元素的border区域为两侧定宽列的所在区域,实现伪等高效果;设置.main的padding和background-clip来实现元素间隔。两侧元素通过负margin调整到.main元素的border区域
缺点: 兼容性不好
top
main
main
left
right
bottom
思路二: absolute
设置子元素的top:0;bottom:0;使得所有子元素的高度都和父元素的高度相同,实现等高效果
缺点: 需要为.middle元素设置高度,扩展性较差
top
main
main
left
right
bottom
思路三: flex
flex中的伸缩项目默认都拉伸为父元素的高度,可实现等高效果。通过改变伸缩项目的order,可以实现元素顺序调换的效果
缺点: 兼容性不高
top
main
main
left
right
bottom
总结
由于限定了主要内容元素在html结构中位于前面,通过css样式改变将其位置调换到中间的前提,所以思路并不是很多。float浮动流的元素可以通过负margin调换位置;absolute绝对定位流的元素可以通过偏移属性调换位置;flex弹性盒模型可以通过order属性调换位置。而处于正常流中的元素除了使用relative外,使用负margin是无法调换位置的,所以table、inline-block等布局方式在此前提下不是很实用。
内容总结
以上是互联网集市为您收集整理的三栏式布局(所谓的圣杯和双飞翼)_html/css_WEB-ITnose全部内容,希望文章能够帮你解决三栏式布局(所谓的圣杯和双飞翼)_html/css_WEB-ITnose所遇到的程序开发问题。 如果觉得互联网集市技术教程内容还不错,欢迎将互联网集市网站推荐给程序员好友。
内容备注
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 gblab@vip.qq.com 举报,一经查实,本站将立刻删除。
内容手机端
扫描二维码推送至手机访问。