美文网首页
html5:div 横向排列的方法

html5:div 横向排列的方法

作者: 卷卷_麦芽呀 | 来源:发表于2019-04-10 15:15 被阅读0次

div 横向排列的方法。

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

<div id="wrap">
    <div id="div1">div1</div>
    <div id="div2">div2</div>
    <div id="div3">div3</div>
</div>

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

float 浮动

#div1{
    float: left;
}
#div2 {
    float: right;
}
#div3 {
    float: right;
}

然后这样了

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

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

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

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

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

inline-block 行块标签

#div1, #div2, #div3{
    display: inline-block;
}

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

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

    1. 通过给父元素设置 font-size: 0; ,使空白符不可见。但会导致子元素中继承的字体大小也为 0,解决方案:
      1. 可以明确子元素内字体大小的,为其单独设置文字大小。
      2. 可以使用 rem 作为字体大小单位来继承 HTML 根元素的字体大小属性。
    2. 在源代码里把前一个 div 的结束标签和后一个 div 的开始标签贴在一起。可读性极差,丑拒。
    <div id="wrap">
        <div id="div1">div1
        </div><div id="div2">div2
        </div><div id="div3">div3</div>
    </div>
    
    1. 不用 inline-block,嘿嘿~
  • 可以换行,如下图

flex 弹性盒模型

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

#wrap{
    display: flex;
}

效果图:

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

#wrap{
    display: flex;
    justify-content: flex-start;
}
flex-start:

默认,图同上。

flex-end:
center:
space-around:
space-between:

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

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

#wrap{
    display: flex;
    flex-wrap: nowrap;
}
nowrap

默认,图略。

wrap
wrap-reverse

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


转载来源:https://blog.csdn.net/hunhun1122/article/details/78591103

相关文章

  • html5:div 横向排列的方法

    div 横向排列的方法。 以下面这组 div 为例,wrap 的高度由内容撑开 平时是这样的,上下排列~ floa...

  • 横向排列div

    效果图(还没画好 将就看吧 就这个意思) html代码 css 第二次效果 html css

  • 实现两列的弹性布局

    需求: 在一个大div内有两个div,横向排列,要求两个div正好占满一行且左边的宽度不固定。如下: 宽度不...

  • div 等块级标签横向排列的方法总结

    块级标签的默认文档流是上下排列的,再配上横向排列的方法,请过适当的嵌套,可以应对几乎所有常见的布局需求,因此,我决...

  • CSS标准文档流,浮动与定位

    标准文档流 定义:块级元素纵向有序排列,行内块(行内)元素横向有序排列 浮动 如果想让四个块级元素 div 并排显...

  • div横向排列+滚动条显示

    实现多个div在容器内横向排列,利用white-space这个属性防止父容器内容换行,同时将容器内元素设置为行内块...

  • Dom

    HTML5 与类相关扩充 1、getElementsByClassName()方法 var div = docum...

  • CSS&JS一些问题

    实现div横向排列,元素往两边撑, 中间自动撑开空格。在父元素里设置 背景图片自适应div 背景图片自适应 tex...

  • 移动端web开发:局部区域滚动

    要实现多个div水平排列,并且自动出现横向滚动条。本来以为只需父级ul元素的overflow-x:auto;ove...

  • 弹性布局

    排列 默认横向正序排列 flex-direction:row 横向倒序排列 flex-direction:row-...

网友评论

      本文标题:html5:div 横向排列的方法

      本文链接:https://www.haomeiwen.com/subject/atnniqtx.html