双飞翼 html 布局,css实现双飞翼布局的四种方法(附代码)

本文详细介绍了CSS实现双飞翼布局的四种方法,包括浮动布局、table-cell布局、绝对定位布局和Flex布局,并给出了相应的代码示例。内容包括如何使左右两侧宽度固定,中间内容宽度自适应。
摘要由CSDN通过智能技术生成

5268f80b9b1e01f982625ef6fac83ca1.png

本篇文章给大家带来的内容是关于css实现双飞翼布局的四种方法(附代码),有一定的参考价值,有需要的朋友可以参考一下,希望对你有所帮助。

圣杯布局、双飞翼布局效果图

c05ea9c79bd9aca3aec433990d461c96.png

从效果图来看圣杯布局、双飞翼布局效果是一样一样的。

圣杯布局、双飞翼布局就是左右两侧宽度固定,中间内容宽度自适应,即100%

圣杯布局

*{

margin: 0;

padding: 0;

box-sizing: border-box;

}

.clearfix:before,

.clearfix:after{

display: table;

content: " ";

clear: both;

}

.container{

padding: 0 200px;

}

.header,

.footer{

height: 200px;

font-size: 28px;

background-color: #f3f3f3;

}

.left{

position: relative;

/* 2、将.left再次拉到最左边,否则.main的左侧会有200px的空白 */

left: -200px;

float: left;

width: 200px;

min-height: 300px;

/* 1、将.left拉到最左边,原来.left是掉下去的 */

margin-left: -100%;

background-color: #f00;

}

.main{

float: left;

width: 100%;

min-height: 300px;

background-color: #c32228;

}

.right{

position: relative;

/* 2、将.right再次拉到最右边,否则.main的右侧会有200px的空白 */

right: -200px;

float: left;

width: 200px;

/*/1、将.right拉到最右边,原来.right是掉下去的 */

margin-left: -200px;

min-height: 300px;

background-color: #f90;

}

header
main
left
right

浮动实现双飞翼布局

*{

margin: 0;

padding: 0;

box-sizing: border-box;

}

.clearfix:before,

.clearfix:after{

display: table;

content: " ";

clear: both;

}

.header,

.footer{

height: 200px;

font-size: 28px;

background-color: #f3f3f3;

}

.left{

float: left;

width: 200px;

min-height: 300px;

/* 将.left拉到最左边,原来.left是掉下去的 */

margin-left: -100%;

background-color: #f00;

}

.main{

float: left;

width: 100%;

min-height: 300px;

/* .left、.right各占了200px,因此需要将其抵消掉 */

padding: 0 200px;

background-color: #c32228;

}

.right{

float: left;

width: 200px;

/* 将.right拉到最右边,原来.right是掉下去的 */

margin-left: -200px;

min-height: 300px;

background-color: #f90;

}

header
main
left
right

table-cell实现双飞翼布局(IE8也兼容哦~)

*{

margin: 0;

padding: 0;

box-sizing: border-box;

}

.container{

display: table;

}

.header,

.footer{

height: 200px;

font-size: 28px;

background-color: #f3f3f3;

}

.left,

.right,

.main{

/* 外层容器使用table-cell布局,设置元素为table-cell布局后它们就能在一行显示了,display: table-cell;设置宽度无效,

因此他们的宽度由内容撑开。 */

display: table-cell;

}

.left-inner{

width: 200px;

min-height: 300px;

background-color: #f00;

}

.main{

width: 100%;

}

.main-inner{

min-height: 300px;

background-color: #c32228;

}

.right-inner{

width: 200px;

min-height: 300px;

background-color: #f90;

}

header
left
main
right

绝对定位实现双飞翼布局

使用绝对定位实现有个小问题:父容器的高度只能由.main的高度来决定

*{

margin: 0;

padding: 0;

box-sizing: border-box;

}

.container{

position: relative;

padding: 0 200px;

}

.header,

.footer{

height: 200px;

font-size: 28px;

background-color: #f3f3f3;

}

.left{

position: absolute;

top: 0;

left: 0;

width: 200px;

min-height: 300px;

background-color: #f00;

}

.main{

min-height: 300px;

background-color: #c32228;

}

.right{

position: absolute;

top: 0;

right: 0;

width: 200px;

min-height: 300px;

background-color: #f90;

}

header
left
mian
right

使用flex实现双飞翼布局(有兼容性问题)

*{

margin: 0;

padding: 0;

box-sizing: border-box;

}

.clearfix:before,

.clearfix:after{

display: table;

content: " ";

clear: both;

}

.container{

display: flex;

}

.header,

.footer{

height: 200px;

font-size: 28px;

background-color: #f3f3f3;

}

.left{

flex: 0 0 200px;

width: 200px;

min-height: 300px;

background-color: #f00;

}

.main{

flex: 1;

width: 100%;

min-height: 300px;

background-color: #c32228;

}

.right{

flex: 0 0 200px;

width: 200px;

min-height: 300px;

background-color: #f90;

}

header
left
main
right

相关推荐:

什么是双飞翼布局?分享一个双飞翼布局的实例代码

CSS布局 圣杯布局 & 双飞翼布局_html/css_WEB-ITnose

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值