使用原生js实现瀑布式加载图片

2024-04-24 00:08

本文主要是介绍使用原生js实现瀑布式加载图片,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

1、首先设置好容器,每张图片的宽度设置为固定宽度,高度自适应

	<div id="main"><div  class="box"><img src="images/0.jpg" /></div>……………………</div>

2、根据电脑分辨率,每排显示的图片数量不同,然后根据图片数量计算出容器的宽度

	var oParent = document.getElementById(parent);var oKids = getKidsByClassName(parent,clsName);var okW = oKids[0].offsetWidth+15; //每一个子元素所占的宽度var num = Math.floor(document.documentElement.clientWidth/okW);//屏幕最多能放多少列var mainW = okW*num;oParent.style.cssText = "width:"+mainW+"px;margin:0 auto"; //让整个容器居中

 3、将容器看成几个列组成,将第一排的列的高度存储在hArr数组中,之后每一个元素都要查找hArr中最低列放置,并修改列的值

	var hArr = [];for(var i = 0; i<oKids.length;i++){if(i<num){hArr.push(oKids[i].offsetHeight+15); //把第一排的列高放进去}else{var minH = Math.min.apply(null,hArr); //找出一列中列高最小的 下一个元素就放在这一列var minIndex = hArr.indexOf(minH);var left = (oKids[i].offsetWidth+15)*minIndex;oKids[i].style.cssText = "position:absolute;top:"+minH+"px;left:"+left+"px;"; //将元素设置成绝对定位,设置top left值hArr.splice(minIndex,1,minH+oKids[i].offsetHeight+15); //修改列高}}

4、实现图片动态加载,通过监听滚动事件,当最高列的最后一个元素露出一半高度时动态加载图片

function checkHeight(){var oParent = document.getElementById("main");var oKids = getKidsByClassName("main","box");var lastKid = oKids[oKids.length-1];var lastH = lastKid.offsetTop+Math.floor(lastKid.offsetHeight/2);//最后一个元素漏出一半高度var scrollH =document.documentElement.scrollTop||document.body.scrollTop;//注意解决兼容性 滚动的高度var screeH = document.body.clientHeight || document.documentElement.clientHeight;//页面高度return lastKid < scrollH+screeH; //当最后一个元素露出一半时 开始加载其他元素}

 

	window.onscroll = function(){if(checkHeight){//当最后一个元素露出一半时 开始加载其他元素var oParent = document.getElementById("main");for(var i = 0;i<dataInt.data.length;i++){var oDiv = document.createElement("div");oDiv.className = "box";oParent.appendChild(oDiv);var oImg = document.createElement("img");oImg.src = "images/"+dataInt.data[i].src;oDiv.appendChild(oImg);}waterfall("main","box"); //调整格式}}

实现效果(第一次录屏,所以录得不好0~0)

效果图

代码地址:https://github.com/Steven37/Waterfall.git

这篇关于使用原生js实现瀑布式加载图片的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/930250

相关文章

MySQL更新某个字段拼接固定字符串的实现

《MySQL更新某个字段拼接固定字符串的实现》在MySQL中,我们经常需要对数据库中的某个字段进行更新操作,本文就来介绍一下MySQL更新某个字段拼接固定字符串的实现,感兴趣的可以了解一下... 目录1. 查看字段当前值2. 更新字段拼接固定字符串3. 验证更新结果mysql更新某个字段拼接固定字符串 -

java实现延迟/超时/定时问题

《java实现延迟/超时/定时问题》:本文主要介绍java实现延迟/超时/定时问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录Java实现延迟/超时/定时java 每间隔5秒执行一次,一共执行5次然后结束scheduleAtFixedRate 和 schedu

Java Optional避免空指针异常的实现

《JavaOptional避免空指针异常的实现》空指针异常一直是困扰开发者的常见问题之一,本文主要介绍了JavaOptional避免空指针异常的实现,帮助开发者编写更健壮、可读性更高的代码,减少因... 目录一、Optional 概述二、Optional 的创建三、Optional 的常用方法四、Optio

C++ Sort函数使用场景分析

《C++Sort函数使用场景分析》sort函数是algorithm库下的一个函数,sort函数是不稳定的,即大小相同的元素在排序后相对顺序可能发生改变,如果某些场景需要保持相同元素间的相对顺序,可使... 目录C++ Sort函数详解一、sort函数调用的两种方式二、sort函数使用场景三、sort函数排序

在Android平台上实现消息推送功能

《在Android平台上实现消息推送功能》随着移动互联网应用的飞速发展,消息推送已成为移动应用中不可或缺的功能,在Android平台上,实现消息推送涉及到服务端的消息发送、客户端的消息接收、通知渠道(... 目录一、项目概述二、相关知识介绍2.1 消息推送的基本原理2.2 Firebase Cloud Me

Spring Boot项目中结合MyBatis实现MySQL的自动主从切换功能

《SpringBoot项目中结合MyBatis实现MySQL的自动主从切换功能》:本文主要介绍SpringBoot项目中结合MyBatis实现MySQL的自动主从切换功能,本文分步骤给大家介绍的... 目录原理解析1. mysql主从复制(Master-Slave Replication)2. 读写分离3.

Redis实现延迟任务的三种方法详解

《Redis实现延迟任务的三种方法详解》延迟任务(DelayedTask)是指在未来的某个时间点,执行相应的任务,本文为大家整理了三种常见的实现方法,感兴趣的小伙伴可以参考一下... 目录1.前言2.Redis如何实现延迟任务3.代码实现3.1. 过期键通知事件实现3.2. 使用ZSet实现延迟任务3.3

基于Python和MoviePy实现照片管理和视频合成工具

《基于Python和MoviePy实现照片管理和视频合成工具》在这篇博客中,我们将详细剖析一个基于Python的图形界面应用程序,该程序使用wxPython构建用户界面,并结合MoviePy、Pill... 目录引言项目概述代码结构分析1. 导入和依赖2. 主类:PhotoManager初始化方法:__in

Java String字符串的常用使用方法

《JavaString字符串的常用使用方法》String是JDK提供的一个类,是引用类型,并不是基本的数据类型,String用于字符串操作,在之前学习c语言的时候,对于一些字符串,会初始化字符数组表... 目录一、什么是String二、如何定义一个String1. 用双引号定义2. 通过构造函数定义三、St

springboot filter实现请求响应全链路拦截

《springbootfilter实现请求响应全链路拦截》这篇文章主要为大家详细介绍了SpringBoot如何结合Filter同时拦截请求和响应,从而实现​​日志采集自动化,感兴趣的小伙伴可以跟随小... 目录一、为什么你需要这个过滤器?​​​二、核心实现:一个Filter搞定双向数据流​​​​三、完整代码