js实现懒加载瀑布流

两种思路用js实现瀑布流式布局,包括懒加载以及自适应。

电脑端效果图
浏览器
手机端效果图
在这里插入图片描述
没有过多注意整体样式,只是给图片加了边框。

方法一

整体思路是将一组图片信息放在一维数组中,计算有多少列,分成该长度的二维数组,遍历数组将图片放到页面中。

html+css

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <meta name="referrer" content="no-referrer">
    <title>Document</title>
    <style>
        *{
     
            margin: 0px;
            padding: 0px;
        }
        img{
     
            width: 100%;
            
        }
        .box{
     
            border: solid 1px black;
            padding: 5px;
            overflow: hidden;
            margin-right: 20px;
            display: inline-block;
            min-width: 230px;
            margin-bottom: 20px;
        }
        #main{
     
            display: flex;
            justify-content: center;
            align-items:flex-start;
        }
        .coloum:nth-last-child(1)>.box{
     
            margin-right: 0px;
        }
    </style>
</head>
<body>
    <div id="main" style="border: solid 2px black;position: relative;overflow: hidden;">
        
    </div>
    <script src="./1.js"></script>
</body>
</html>

js代码

const img1 = [
    {
   
        name:'图片1',
        path:'https://c-ssl.duitang.com/uploads/item/202003/02/20200302200934_ewenx.thumb.400_0.jpg'
    },
    {
   
        name:'图片2',
        path:'https://c-ssl.duitang.com/uploads/blog/202009/02/20200902161748_ad413.thumb.400_0.jpg'
    },
    {
   
        name:'图片3',
        path:'https://c-ssl.duitang.com/uploads/blog/202106/06/20210606123318_9846b.thumb.400_0.jpg'
    },
    {
   
        name:'图片4',
        path:'https://c-ssl.duitang.com/uploads/blog/202011/21/20201121002940_60e6a.thumb.400_0.jpg'
    },{
   
        name:'图片5',
        path:'https://c-ssl.duitang.com/uploads/blog/202009/13/20200913024331_Tfrnh.thumb.400_0.jpeg'
    },
    {
   
        name:'图片6',
        path:'https://c-ssl.duitang.com/uploads/item/201503/30/20150330224142_WrQ3M.thumb.400_0.jpeg'
    },
    {
   
        name:'图片7',
        path:'https://c-ssl.duitang.com/uploads/blog/202106/06/20210606123318_9846b.thumb.400_0.jpg'
    },
    {
   
        name:'图片8',
        path:'https://c-ssl.duitang.com/uploads/item/202005/16/20200516191851_xecnm.thumb.400_0.png'
    },
    {
   
        name:'图片9',
        path:'https://c-ssl.duitang.com/uploads/item/201503/30/20150330224142_WrQ3M.thumb.400_0.jpeg'
    },
    {
   
        name:'图片10',
        path:'https://c-ssl.duitang.com/uploads/blog/202106/06/20210606123318_9846b.thumb.400_0.jpg'
    },
    {
   
        name:'图片11',
        path:'https://c-ssl.duitang.com/uploads/item/202005/16/20200516191851_xecnm.thumb.400_0.png'
    },
    {
   
        name:'图片12',
        path:'https://c-ssl.duitang.com/uploads/blog/202009/02/20200902161748_ad413.thumb.400_0.jpg'
    },
    {
   
        name:'图片13',
        path:'https://c-ssl.duitang.com/uploads/blog/202106/06/20210606123318_9846b.thumb.400_0.jpg'
    },
    {
   
        name:'图片14',
        path:'https://c-ssl.duitang.com/uploads/blog/202106/06/20210606123318_9846b.thumb.400_0.jpg'
    },
    {
   
        name:'图片15',
        path:'https://c-ssl.duitang.com/uploads/blog/202011/21/20201121002940_60e6a.thumb.400_0.jpg'
    }
    ,{
   
        name:'图片16',
        path:'https://c-ssl.duitang.com/uploads/blog/202009/13/20200913024331_Tfrnh.thumb.400_0.jpeg'
    },
    {
   
        name:'图片17',
        path:'https://c-ssl.duitang.com/uploads/blog/202106/06/20210606123318_9846b.thumb.400_0.jpg'
    },
    {
   
        name:'图片18',
        path:'https://c-ssl.duitang.com/uploads/blog/202106/06/20210606123318_9846b.thumb.400_0.jpg'
    },
    {
   
        name:'图片19',
        path:'https://c-ssl.duitang.com/uploads/blog/202011/21/20201121002940_60e6a.thumb.400_0.jpg'
    }
    ,{
   
        name:'图片20',
        path:'https://c-ssl.duitang.com/uploads/blog/202009/13/20200913024331_Tfrnh.thumb.400_0.jpeg'
    },
    {
   
        name:'图片17',
        path:'https://c-ssl.duitang.com/uploads/blog/202106/06/20210606123318_9846b.thumb.400_0.jpg'
    },
    {
   
        name:'图片18',
        path:'https://c-ssl.duitang.com/uploads/blog/202106/06/20210606123318_9846b.thumb.400_0.jpg'
    },
    {
   
        name:'图片19',
        path:'https://c-ssl.duitang.com/uploads/blog/202011/21/20201121002940_60e6a.thumb.400_0.jpg'
    }
    ,{
   
        name:'图片20',
        path:'https://c-ssl.duitang.com/uploads/blog/202009/13/20200913024331_Tfrnh.thumb.400_0.jpeg'
    },
    
]


const img2 = [
    {
   
        name:'图片1',
        path
  • 2
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值