html5中div怎么横着写,html5:div 横向排列的方法

本文介绍了几种使用CSS实现div元素横向排列的方法,包括利用float属性、display属性的inline-block值及flex弹性盒模型。每种方法都有其特点与适用场景,并详细解释了各自的优缺点。

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

div 横向排列的方法。

以下面这组 div 为例,wrap 的高度由内容撑开

div1
div2
div3

平时是这样的,上下排列~

57ddf82cc7e5?utm_campaign=maleskine&utm_content=note&utm_medium=seo_notes&utm_source=recommendation

float 浮动

#div1{

float: left;

}

#div2 {

float: right;

}

#div3 {

float: right;

}

然后这样了

57ddf82cc7e5?utm_campaign=maleskine&utm_content=note&utm_medium=seo_notes&utm_source=recommendation

成功横向排列了,但是有几个问题~

float 的特点:

多个 div 右浮动时,顺序会颠倒,请注意看 div2 和 div3,可以通过将它们再用一个 div 包起来,然后对它们设置左浮动,对父 div 设置右浮动来解决。

脱离文档流,若父元素高度由内容撑开,那么就撑不开,从图中可以看到 wrap 没了,因为高度变为了 0,可通过清浮动来解决。

文字会环绕在浮动元素周围,图中未表现出来。

不能换行,图中未表现出来。

inline-block 行块标签

#div1, #div2, #div3{

display: inline-block;

}

57ddf82cc7e5?utm_campaign=maleskine&utm_content=note&utm_medium=seo_notes&utm_source=recommendation

横排成功~但同样有些问题:

inline-block 特点:

元素间会有空白。这个空白其实是空白符,因为 inline-block 会使元素在行内排列,也就是跟文字在一起排列,而我们源代码中 div 和 div 之间的空格、Tab、换行符在浏览器里会被合并成一个空白符,所以就会出现缝隙,常见的解决方案有:

通过给父元素设置 font-size: 0; ,使空白符不可见。但会导致子元素中继承的字体大小也为 0,解决方案:

可以明确子元素内字体大小的,为其单独设置文字大小。

可以使用 rem 作为字体大小单位来继承 HTML 根元素的字体大小属性。

在源代码里把前一个 div 的结束标签和后一个 div 的开始标签贴在一起。可读性极差,丑拒。

div1
div2
div3

不用 inline-block,嘿嘿~

可以换行,如下图

flex 弹性盒模型

最爱的解决方案,给父元素设置 display: flex; 即可。

#wrap{

display: flex;

}

效果图:

57ddf82cc7e5?utm_campaign=maleskine&utm_content=note&utm_medium=seo_notes&utm_source=recommendation

还可以通过 justify-content 属性调整子元素的水平对齐方式:

#wrap{

display: flex;

justify-content: flex-start;

}

flex-start:

默认,图同上。

flex-end:

57ddf82cc7e5?utm_campaign=maleskine&utm_content=note&utm_medium=seo_notes&utm_source=recommendation

center:

57ddf82cc7e5?utm_campaign=maleskine&utm_content=note&utm_medium=seo_notes&utm_source=recommendation

space-around:

57ddf82cc7e5?utm_campaign=maleskine&utm_content=note&utm_medium=seo_notes&utm_source=recommendation

space-between:

57ddf82cc7e5?utm_campaign=maleskine&utm_content=note&utm_medium=seo_notes&utm_source=recommendation

不过当父元素宽度不够时, flex 默认是不会换行的,而是会等比例压缩,缩放比例 flex-shrink 属性或复合属性 flex 相关。

57ddf82cc7e5?utm_campaign=maleskine&utm_content=note&utm_medium=seo_notes&utm_source=recommendation

通过 flex-wrap 属性可以使其换行,该值有三个取值 nowrap、 wrap、 wrap-reverse,默认为 nowrap。

#wrap{

display: flex;

flex-wrap: nowrap;

}

nowrap

默认,图略。

wrap

57ddf82cc7e5?utm_campaign=maleskine&utm_content=note&utm_medium=seo_notes&utm_source=recommendation

wrap-reverse

57ddf82cc7e5?utm_campaign=maleskine&utm_content=note&utm_medium=seo_notes&utm_source=recommendation

flex 使用不再深入探讨,推荐阮一峰写的教程 Flex 布局教程:语法篇

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值