html5三列固定宽度布局代码,css实现左右顶头、宽度自适应的多列、多块并排,多列布局...

本文探讨了如何使用CSS解决三列并排布局的问题,对比了使用float和inline-block两种方法的优缺点。在float布局中,通过调整元素顺序解决了间隙问题;而在inline-block布局中,通过嵌套元素和负margin实现了间隔。每种方法都有其适用场景和可能的副作用,开发者可以根据需求选择合适的方法。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

今天在工作中遇到了一个问题:有三个div块,里面放置展示内容,并排,中间有间隙,两边顶头,可以随屏幕大小自适应宽度。

我第一时间想到的是传统的三列布局,但传统的三列布局都是固定宽度加自适应宽度,从网上搜了好久都没有搜到结果。所以自己想办法。

第一种想到的办法:

第一种我准备用两边float,中间margin居中的方法。代码如下:

css:

.wrap{height:300px;width:95%;margin: 100px auto;}

.left{float:left;width:32%;height:100px;background-color: #235255}

.right{float:right;width:32%;height:100px;background-color: #374737}

.middle{width:32%;margin:0 auto;height:100px;background-color: #563958}

html:

结果变成了这样:

bVqVkl

查了一下,解决办法是把right提到最前面。试了一下,成功了。

html:

bVqVlP

不过思考一下,这个问题有很多的不方便。首先就是可能会打乱html的加载顺序,还有就是间距是不固定的,并且加了float,可能会有副作用。

之后我就考虑第二种方案。问了下同事,提到了可以用inline-block代替float的方法。这给了我很大的启发。回来我就试了一下。

第二种想到的办法

这种方法将这三个块都设置成display:inline-block,利用inline元素的特性将其居于一行,再将其box-sizing属性设置成border-box。

这种方法,好处有几点:

1.不会有float的副作用存在

2.不管是三列还是三十列,来就行

代码如下:

css:

.g-bd{width: 95%;height: 300px;padding-top:20px;background-color: #bbbbbb;margin: 0 auto;}

.in-bl{display: inline-block;}

.f{width: 33.333%;height: 100px;background-color: #ab1256;}

.s{width: 33.333%;height: 100px;}

.t{width: 33.333%;height: 100px;background-color:#192873;}

html:

结果与预想的不太相同。预想中他们之间没有空隙,充满容器,不会换行。结果他们义无反顾地换行了,之间有了一个本不该存在的空隙。

原因也很简单,作为一个带有inline的元素之间换行是会被识别为空格的(哭)。

原理找到了,这里有详细的解释,鑫旭大神就是厉害:张鑫旭对于inline-block的理解。这里是个demo,就用最简单的方法去除空格就好了。

接下来还有个问题:无法通过margin/padding来给他们之间设置间隔。这里想了一个办法:在每个盒子里面嵌套一个盒子,背景设置给里面的,宽度设置比100%小一点,通过margin:auto进行调整位置,这样就有一个可以调整的间隙了~

代码如下:

css:

.g-bd{width: 95%;height: 300px;padding-top:20px;background-color: #bbbbbb;margin: 0 auto;}

.in-bl{display: inline-block;}

.f{width: 33.333%;height: 100px;background-color: #ab1256;}

.s{width: 33.333%;height: 100px;}

.t{width: 33.333%;height: 100px;background-color:#192873;}

.in{margin:0 auto;px;width: 95%;background-color:#958727;height: 100%}

html:

效果:

bVqVIk

大功告成。这样的方法会增加一个嵌套,要设置border-box,也算是有些副作用了。到工作时再根据需要进行取舍吧。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值