各位前端老哥来看看这种照片墙怎么实现最好? - V2EX
oukichi

各位前端老哥来看看这种照片墙怎么实现最好?

  •  
  •   oukichi Apr 7, 2023 5117 views
    This topic created in 1133 days ago, the information mentioned may be changed or developed.

    image.png

    我现在是用 js 算的绝对定位铺上去的,可是每当窗口 resize 的时候,就会多少出现点问题。 各位前端大兄弟可有妙计? 或者可以推荐给我一个什么库吗? 谢谢各位!

    17 replies    2023-04-07 17:51:39 +08:00
    acthtml
        1
    acthtml  
       Apr 7, 2023   1
    自己写一个,思路:先装大石头,再装小沙子。

    先随机大的图并确定位置,例如 3x3, 2x2 ,其余部分用 1x1 的图填充。
    dawnven
        2
    dawnven  
    PRO
       Apr 7, 2023   1
    要实现一个照片墙,可以使用前端框架 (如 React 、Angular 、Vue 等) 以及相应的库或组件。以下是一些可能有用的库或组件:

    React GridLayout:这是一个用于在 React 中实现网格布局的库。它可以帮助你轻松地创建具有不同大小照片的照片墙。

    Ng-Grid:这是一个用于 Angular 的网格布局库。它也可以帮助你创建照片墙,并且提供了一些选项来控制照片的大小和排列方式。

    VueGridster:这是一个用于 Vue.js 的网格布局组件,它可以帮助你轻松地创建照片墙。它支持不同大小的照片,并且可以根据需要自定义布局。

    Photo Gallery:这是一个用于 React 的相册组件,它可以轻松地显示多张照片,并且可以根据需要自定义样式。

    Pixastic:这是一个用于 Javascript 的图像处理库,它可以将照片墙转换为动画效果。

    以上这些库或组件都可以用于实现照片墙,具体选择哪一个取决于你的需求和偏好。



    --------------------------
    我帮你问 chatgpt 了
    Seanfuck
        4
    Seanfuck  
       Apr 7, 2023
    瀑布流,数量固定的话 table ,图片用背景图填充方式
    throns
        5
    throns  
       Apr 7, 2023 via iPhone   1
    oukichi
        6
    oukichi  
    OP
       Apr 7, 2023
    @dawnven 哈哈哈,gpt 说话味道很明显
    henryxie2093
        7
    henryxie2093  
       Apr 7, 2023
    这不是 https://www.artstation.com 吗?
    看下人家页面怎么写的
    icebay
        9
    icebay  
       Apr 7, 2023
    昨天刚好有用这个。

    https://github.com/metafizzy/isotope
    jifengg
        10
    jifengg  
       Apr 7, 2023
    用库固然是一个好办法,不过这个貌似不复杂,你不妨贴一下你具体遇到的问题。我刚花点时间写了一个,没碰到 resize 有问题。
    kongkx
        11
    kongkx  
       Apr 7, 2023 via iPhone
    display grid 。加上 nth-child 应该能处理
    shabbyin
        12
    shabbyin  
       Apr 7, 2023 via iPhone
    grid 会自动填充到合适的位置 比 flex 更智能
    6IbA2bj5ip3tK49j
        13
    6IbA2bj5ip3tK49j  
       Apr 7, 2023
    如果不需要跨行的话。可以看看 http://miromannino.github.io/Justified-Gallery/getting-started/
    phub2020
        14
    phub2020  
       Apr 7, 2023
    一楼的老哥想法就很好,如果不用已有的轮子的话,那先准备盒子,再填充内容就很不错
    urnoob
        15
    urnoob  
       Apr 7, 2023
    我是纯后端
    再大的图片都是小图片组成的,标记使用过的区域(二维数组),用算法选择合适大小图片,外加点随机大小图。剩下 resize 就应该是 css 相关了吧
    tomcats
        16
    tomcats  
       Apr 7, 2023 via iPhone
    Transform scale 整体缩放
    Envov
        17
    Envov  
       Apr 7, 2023
    grid 应该可以实现
    About     Help     Advertise     Blog     API     FAQ     Solana     4989 Online   Highest 6679       Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 102ms UTC 01:07 PVG 09:07 LAX 18:07 JFK 21:07
    Do have faith in what you're doing.
    ubao msn snddm index pchome yahoo rakuten mypaper meadowduck bidyahoo youbao zxmzxm asda bnvcg cvbfg dfscv mmhjk xxddc yybgb zznbn ccubao uaitu acv GXCV ET GDG YH FG BCVB FJFH CBRE CBC GDG ET54 WRWR RWER WREW WRWER RWER SDG EW SF DSFSF fbbs ubao fhd dfg ewr dg df ewwr ewwr et ruyut utut dfg fgd gdfgt etg dfgt dfgd ert4 gd fgg wr 235 wer3 we vsdf sdf gdf ert xcv sdf rwer hfd dfg cvb rwf afb dfh jgh bmn lgh rty gfds cxv xcv xcs vdas fdf fgd cv sdf tert sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf shasha9178 shasha9178 shasha9178 shasha9178 shasha9178 liflif2 liflif2 liflif2 liflif2 liflif2 liblib3 liblib3 liblib3 liblib3 liblib3 zhazha444 zhazha444 zhazha444 zhazha444 zhazha444 dende5 dende denden denden2 denden21 fenfen9 fenf619 fen619 fenfe9 fe619 sdf sdf sdf sdf sdf zhazh90 zhazh0 zhaa50 zha90 zh590 zho zhoz zhozh zhozho zhozho2 lislis lls95 lili95 lils5 liss9 sdf0ty987 sdft876 sdft9876 sdf09876 sd0t9876 sdf0ty98 sdf0976 sdf0ty986 sdf0ty96 sdf0t76 sdf0876 df0ty98 sf0t876 sd0ty76 sdy76 sdf76 sdf0t76 sdf0ty9 sdf0ty98 sdf0ty987 sdf0ty98 sdf6676 sdf876 sd876 sd876 sdf6 sdf6 sdf9876 sdf0t sdf06 sdf0ty9776 sdf0ty9776 sdf0ty76 sdf8876 sdf0t sd6 sdf06 s688876 sd688 sdf86