jquery实现简单瀑布流布局(续):图片懒加载
jquery实现简单瀑布流布局(续):图片懒加载
这篇文章是jquery实现简单瀑布流布局思想的小小扩展。代码基于前作的代码继续完善。
图片懒加载就是符合某些条件时才触发图片的加载。最常见的具体表现就是,当页面被请求时,只加载可视区域的图片,其它部分的图片只占位而不加载,只有这些图片出现在可视区域时才会动态加载。具体实现的技术并不复杂,下面分别对其说明。
技术路线
- 怎么加载。首先未加载的图片有一个占位假图片(一般是loading),按照真实图片的大小进行样式化。网上较为常用的思路是对图片元素的父级定义一个
data-src
属性,用来存放该图片元素的真实src。到用的时候再调用。 - 加载判断条件:
首屏一次性加在20张。保证首页有料。
后边的图片基于以下思路。
往下拉(滚动),找到第一个顶部进入可视区的img,优先加载。
- 监听位置:
- 滚动条滚动时,这提示需要写一个新加载的函数。
- 第二个有点难察觉,就是在getlist方法加载瀑布流完结之前。因为getList一旦调用,就意味着有新的图片进入可视区。不能只靠滚动进行触发
修改getList函数
function getList(n){
$.getJSON(createUrl(n),function(data){
if(data.length==0){
return false;
}else{
for(var i=0;i<data.length;i++){
var $html=null;
if(i<=20&&n==1){//首屏一次加载20张
$html=$('<div><img src="'+data[i].preview+'"><p>'+data[i].title+'</p></div>');
}else{
$html=$('<div><img src="images/1.jpg"><p>'+data[i].title+'</p></div>');
$html.find('img').css('opacity','0'); //占位图片不透明度为0
}
$('li').eq(getShortestLi()).append($html);
$html.attr('data-src',data[i].preview);
$html.find('img').css('height',(data[i].height*225/data[i].width)+'px');
$html.find('img').css('width','225px');
};
}
bCheck=true;
});
}
加载真实图片的执行函数
function loadClientPic(arr){//arr是页面所有的img标签。
var scrollTop=document.documentElement.scrollTop||document.body.scrollTop;
for(var i=0;i<arr.length;i++){
if(arr.eq(i).attr('src')=='images/1.jpg'){
if(arr.eq(i).offset().top<document.documentElement.clientHeight+scrollTop){//进入可视区内!
arr.eq(i).attr('src',arr.eq(i).parent().attr('data-src'));
//console.log(i)
//transition: 1s; opacity: 1
if(arr.eq(i).attr('src')!=='images/1.jpg'&&arr.eq(i).height()!==0){
arr.eq(i).css('transition','1s').css('opacity','1');
}
}else{
//console.log('不在可视区!')
}
}else{
//console.log('已加载')
}
}
};
最后,在监听位置加上写好的函数
- 在$(window).scroll(function(){})里加上loadClientPic($('img));
- 不要遗漏getList方法结束前也执行loadClientPic。
附录
demo地址 http://djtao.top/ppl/ppl.html
全部代码:
//找出高度最小li的索引值
function getShortestLi(){
var shortest=0;
for(var i=1;i<4;i++){
if($('li').eq(i).height()<$('li').eq(shortest).height()){
shortest=i;
}
}
return shortest;
}
function createUrl(num){
return 'http://www.wookmark.com/api/json/popular?page='+num+'&callback=?';
}
var bCheck=false;
function getList(n){
$.getJSON(createUrl(n),function(data){
if(data.length==0){
return false;
}else{
for(var i=0;i<data.length;i++){
var $html=null;
if(i<=20&&n==1){//首屏一次加载20张
$html=$('<div><img src="'+data[i].preview+'"><p>'+data[i].title+'</p></div>');
}else{
$html=$('<div><img src="images/1.jpg"><p>'+data[i].title+'</p></div>');
$html.find('img').css('opacity','0'); //占位图片不透明度为0
}
$('li').eq(getShortestLi()).append($html);
$html.attr('data-src',data[i].preview);
$html.find('img').css('height',(data[i].height*225/data[i].width)+'px');
$html.find('img').css('width','225px');
};
}
loadClientPic($('img'));//函数临结束执行判断
bCheck=true;
});
}
$(function(){
var pageNum=1;
getList(pageNum);
$(window).scroll(function(){
var $li=$('li').eq(getShortestLi());
var scrollTop=document.documentElement.scrollTop||document.body.scrollTop;
//console.log([$li.offset().top+$li.height(),document.documentElement.clientHeight+scrollTop])
//如果li高度与li到页面顶部的高度之和<可视区高度+滚动距离
if($li.offset().top+$li.height()<document.documentElement.clientHeight+scrollTop){
if(bCheck){
bCheck=false;
pageNum++;
//console.log(pageNum);
getList(pageNum);
}else{
return false;
}
}
loadClientPic($('img'));
})
})
function loadClientPic(arr){
var scrollTop=document.documentElement.scrollTop||document.body.scrollTop;
for(var i=0;i<arr.length;i++){
if(arr.eq(i).attr('src')=='images/1.jpg'){
if(arr.eq(i).offset().top<document.documentElement.clientHeight+scrollTop){//进入可视区内!
arr.eq(i).attr('src',arr.eq(i).parent().attr('data-src'));
//console.log(i)
//transition: 1s; opacity: 1
if(arr.eq(i).attr('src')!=='images/1.jpg'&&arr.eq(i).height()!==0){
arr.eq(i).css('transition','1s').css('opacity','1');
}
}else{
//console.log('不在可视区!')
}
}else{
//console.log('已加载')
}
}
};
看着那些图片,不由得再感叹一句,歪果仁太会玩了..
jquery实现简单瀑布流布局(续):图片懒加载的更多相关文章
- jquery实现简单瀑布流布局
jquery实现简单瀑布流布局 是开头都会说的原理 瀑布流布局有两种,一种是固定列,一种是非固定列.在此主要记述第一种的实现. 固定列的特征是:无论页面如何缩放,每行的总列数都一致. 一行4列的瀑布流 ...
- 代码: 两列图片瀑布流(一次后台取数据,图片懒加载。下拉后分批显示图片。图片高度未知,当图片onload后才显示容器)
代码: 两列图片瀑布流(一次后台取数据,无ajax,图片懒加载.下拉后分批显示图片.图片高度未知,当图片onload后才显示容器) [思路]: 图片瀑布流,网上代码有多种实现方式,也有各类插件.没找到 ...
- jQuery图片懒加载插件jquery.lazyload.js使用实例注意事项说明
jQuery图片懒加载插件jquery.lazyload.js使用实例注意事项说明 jquery.lazyload.js是一个用JavaScript编写的jQuery插件.它可以延迟加载长页面中的图片 ...
- jQuery插件图片懒加载lazyload
来自XXX的前言: 什么是ImageLazyLoad技术 在页面上图片比较多的时候,打开一张页面必然引起与服务器大数据量的 交互.尤其是对于高清晰的图片,占的几M的空间.ImageLazyLoad技术 ...
- [jQuery插件]手写一个图片懒加载实现
教你做图片懒加载插件 那一年 那一年,我还年轻 刚接手一个ASP.NET MVC 的 web 项目, (C#/jQuery/Bootstrap) 并没有做 web 的经验,没有预留学习时间, (作为项 ...
- jQuery.imgLazyLoad图片懒加载组件
一.前言 当一个页面中请求的图片过多,而且图片太大,页面访问的速度是非常慢的,对用户的体验非常不友好:使用图片懒加载,可以减轻服务器的压力,增加页面的访问量,这里主要是总结一下我自己写的图片懒加载组件 ...
- jquery图片懒加载效果
1.要引入jquery 2.要引入underscore.js <!DOCTYPE html> <html lang="en"> <head> & ...
- 插件:★★★ !!!图片懒加载 lazyload.js 、 jquery.scrollLoading.js
插件:图片懒加载 jquery.lazyload.js 2016-3-31 插件说明:http://www.w3cways.com/1765.html (小插件,好用) 下载地址: https://r ...
- 使用jQuery实现图片懒加载原理
原文:https://www.liaoxuefeng.com/article/00151045553343934ba3bb4ed684623b1bf00488231d88d000 在网页中,常常需要用 ...
随机推荐
- 烂泥:dnsmasq搭建简易DNS服务器
本文由ilanniweb提供友情赞助,首发于烂泥行天下 想要获得更多的文章,可以关注我的微信ilanniweb. 今天我们来介绍一个比较简单的DNS服务器dnsmasq.这款软件,已经被我成功使用到公 ...
- 解惑spring嵌套事物
工作中一直对spring中的事物管理都是最简单的配置 但是spring中的事物传播性配置 还有很多种,有时候经常疑惑service调用service的问题,今天的论坛上看到一篇写的非常详细的文字.记录 ...
- 系统集成方案(一).NET集成方案
NET系统集成有自己独立的登录验证方式.比如,跟报表集成时,不需要再使用报表内置的登录界面,只需要将报表默认的参数用户名fr_username和密码fr_password发送给报表系统,触发一下报表验 ...
- 阅读Real-Time O(1) Bilateral Filtering 一文的相关感受。
研究双边滤波有很长一段时间了,最近看了一篇Real-Time O(1) Bilateral Filtering的论文,标题很吸引人,就研读了一番,经过几天的攻读,基本已理解其思想,现将这一过程做一简单 ...
- 【原】移动web页面支持弹性滚动的3个方案
有段时间一直折腾移动端页面弹性滚动的各种问题,做了点研究,今天做个小分享~ 传统 pc 端中,子容器高度超出父容器高度,通常使用 overflow:auto 可出现滚动条拖动显示溢出的内容,而移动we ...
- BZOJ 3531: [Sdoi2014]旅行 [树链剖分]
3531: [Sdoi2014]旅行 Time Limit: 20 Sec Memory Limit: 512 MBSubmit: 1685 Solved: 751[Submit][Status] ...
- POJ3928Ping pong[树状数组 仿逆序对]
Ping pong Time Limit: 1000MS Memory Limit: 65536K Total Submissions: 3109 Accepted: 1148 Descrip ...
- MyBatis入门案例、增删改查
一.MyBatis入门案例: ①:引入jar包 ②:创建实体类 Dept,并进行封装 ③ 在Src下创建大配置mybatis-config.xml <?xml version="1.0 ...
- TortoiseSVN 中 一个 Merge revisions to.. 小坑
注意: 不能只选头与尾svn号, 一定要全选 !!全选 !!全选 !!
- Xcode8与iOS10那些事
一.证书管理 用Xcode8打开工程后,比较明显的就是下图了,这个是苹果的新特性,可以帮助我们自动管理证书.建议大家勾选这个Automatically manage signing(Ps.但是在bea ...