CSS3中的砌体布局?

 mobiledu2502926601 发布于 2023-02-13 16:43

我尝试使用以下结构来生成下面描述的布局.

child 1
child 2
child 3
child 4

我在这里做了一个例子.

布局应如下:

如果flexbox中只有一个盒子,它应该具有Flexbox内部宽度的50%(见下图)

在此输入图像描述

如果有两个盒子,它们都应该占用Flexbox内50%的空间

在此输入图像描述

如果有三个盒子,每个盒子应占50%的空间,而前两个盒子在第1行,第三个盒子在第2行

在此输入图像描述

我怎样才能用css实现这种布局?

编辑:框可能没有相同的高度.这意味着他们应该垂直填充剩余的空间.宽度始终相同.有关示例,请参见下图.

在此输入图像描述

编辑:我找到了一种用纯css制作砖石的方法,请看这里:http://jsfiddle.net/confile/aGXzU/

问题是盒子的顺序错误.它们应该是从左到右,从上到下,如下所示:

1 2 3
4 5 6 
7 8 9

有没有办法用css和只有一点点javascript来获得这个?

2 个回答
  • 这是一个新的答案,并希望它解决你的问题,跟随两个小提琴,来处理这个问题,第一个脚本将抛出所有奇怪的孩子在左侧,所有甚至孩子在右侧

    side1=0,side2=0
    
    $(".flexbox").children().each(function(index, element) {
        if (index % 2 === 0) //odd children (starts with 0 )
        {
    $(this).css("top",side1+"px") 
    side1+=parseInt($(this).css("height"))
        }
    else //even children
        {
    $(this).css("top",side2+"px")
    $(this).css("left","50%") 
    side2+=parseInt($(this).css("height"))
        }   
    });
    

    http://jsfiddle.net/prollygeek/QD9kZ/

    而这第二个小提琴,将根据元素高度平衡双方,使列高度始终没有大的偏差,使用它们的任何脚本都取决于你.

    side1=0,side2=0
    $(".flexbox").children().each(function(index, element) {
    if(side1<=side2)
    {
    $(this).css("top",side1+"px") 
    side1+=parseInt($(this).css("height"))
    }
    else if(side2<side1)
    {
    $(this).css("top",side2+"px")
    $(this).css("left","50%") 
    side2+=parseInt($(this).css("height"))
    }
    
    });
    

    http://jsfiddle.net/prollygeek/hP6fS/

    2023-02-13 16:46 回答
  • Flexbox不能用于重新创建Masonry布局.期.

    Flexbox用于控制元素沿水平行(flex-direction: row默认情况下)或垂直列(flex-direction: column)的流动方式.这意味着您只能在一个方向上消除多余空间:左/右(行)或上/下(列).因为flex-direction: column需要一个明确的高度来启用包装,所以它完全不适合这个目的.

    在CSS多列布局模块是你可以使用纯CSS再造一个砌体布局最接近的,但它仍然只允许你消除的元素之间的多余空间在一个方向:垂直.这个和Flexbox之间的关键区别(使用列方向)是多列模块不需要明确的高度,并且会尽可能地在每个列之间平均分配内容(这可以通过列控制 - 填写属性).列之间的间隙由列间隙属性控制.

    http://codepen.io/cimmanon/pen/CcGlE

    .my-element {
      -moz-columns: 15em;
      -webkit-columns: 15em;
      columns: 15em;
    }
    

    2023-02-13 16:46 回答
撰写答案
今天,你开发时遇到什么问题呢?
立即提问
热门标签
PHP1.CN | 中国最专业的PHP中文社区 | PNG素材下载 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有