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实现简单瀑布流布局(续):图片懒加载的更多相关文章

  1. jquery实现简单瀑布流布局

    jquery实现简单瀑布流布局 是开头都会说的原理 瀑布流布局有两种,一种是固定列,一种是非固定列.在此主要记述第一种的实现. 固定列的特征是:无论页面如何缩放,每行的总列数都一致. 一行4列的瀑布流 ...

  2. 代码: 两列图片瀑布流(一次后台取数据,图片懒加载。下拉后分批显示图片。图片高度未知,当图片onload后才显示容器)

    代码: 两列图片瀑布流(一次后台取数据,无ajax,图片懒加载.下拉后分批显示图片.图片高度未知,当图片onload后才显示容器) [思路]: 图片瀑布流,网上代码有多种实现方式,也有各类插件.没找到 ...

  3. jQuery图片懒加载插件jquery.lazyload.js使用实例注意事项说明

    jQuery图片懒加载插件jquery.lazyload.js使用实例注意事项说明 jquery.lazyload.js是一个用JavaScript编写的jQuery插件.它可以延迟加载长页面中的图片 ...

  4. jQuery插件图片懒加载lazyload

    来自XXX的前言: 什么是ImageLazyLoad技术 在页面上图片比较多的时候,打开一张页面必然引起与服务器大数据量的 交互.尤其是对于高清晰的图片,占的几M的空间.ImageLazyLoad技术 ...

  5. [jQuery插件]手写一个图片懒加载实现

    教你做图片懒加载插件 那一年 那一年,我还年轻 刚接手一个ASP.NET MVC 的 web 项目, (C#/jQuery/Bootstrap) 并没有做 web 的经验,没有预留学习时间, (作为项 ...

  6. jQuery.imgLazyLoad图片懒加载组件

    一.前言 当一个页面中请求的图片过多,而且图片太大,页面访问的速度是非常慢的,对用户的体验非常不友好:使用图片懒加载,可以减轻服务器的压力,增加页面的访问量,这里主要是总结一下我自己写的图片懒加载组件 ...

  7. jquery图片懒加载效果

    1.要引入jquery 2.要引入underscore.js <!DOCTYPE html> <html lang="en"> <head> & ...

  8. 插件:★★★ !!!图片懒加载 lazyload.js 、 jquery.scrollLoading.js

    插件:图片懒加载 jquery.lazyload.js 2016-3-31 插件说明:http://www.w3cways.com/1765.html (小插件,好用) 下载地址: https://r ...

  9. 使用jQuery实现图片懒加载原理

    原文:https://www.liaoxuefeng.com/article/00151045553343934ba3bb4ed684623b1bf00488231d88d000 在网页中,常常需要用 ...

随机推荐

  1. Jsoup做接口测试

    最早用Jsoup是有一个小的爬虫应用要写,发现Jsoup较HttpClient轻便多了,API也方便易懂,上手很快,对于response的Document解析的选择器用的是cssSelector(Jq ...

  2. MySQL server has gone away报错原因分析/

    在平时和开发的交流 以及 在论坛回答问题的或称中会发现这个问题被问及的频率非常高. 程序中报错: MySQL server has gone away 是什么意思? 如何避免? 因此,感觉有必要总结一 ...

  3. 使用FileZilla等软件搭建ftp服务器

    FTP的全称是File Transfer Protocol(文件传输协议).顾名思义,就是专门用来传输文件的协议. FTP服务器,则是在互联网上提供存储空间的计算机,它们依照FTP协议提供服务.简单地 ...

  4. delphi WebBrowser控件上网页验证码图片识别教程(一)

    步骤一:获取网页中验证码图片的url地址 在delphi中加入一个BitBtn和一个memo以及WebBrowser控件实现网页中验证码图片的url地址的获取 程序如下:procedure TForm ...

  5. MMORPG大型游戏设计与开发(服务器 AI 基础接口)

    一个模块都往往需要统一的接口支持,特别是对于非常大型的模块,基础结构的统一性非常重要,它往往决定了其扩展对象的通用性.昨天说了AI的基本概述以及组成,作为与场景模块中核心一样重要的地位,基础部分的设计 ...

  6. NopCommerce 增加 Customer Settings

    预期: 仿照Customer 的 Phone number enabled 和 required 增加MemberType 相关步骤如下: 1.运行站点 Admin -> Settings -& ...

  7. HDU 1524 A Chess Game【SG函数】

    题意:一个N个点的拓扑图,有M个棋子,两个人轮流操作,每次操作可以把一个点的棋子移动到它的一个后继点上(每个点可以放多个棋子),直到不能操作,问先手是否赢. 思路:DFS求每个点的SG值,没有后继的点 ...

  8. HDU1890 Robotic Sort[splay 序列]

    Robotic Sort Time Limit: 6000/2000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others)Tota ...

  9. Jenkins学习四:Jenkins 邮件配置

    本文主要对Windows环境 jenkins 的邮件通知进行介绍 jenkins 内置的邮件功能 使用email-ext插件扩展的邮件功能 邮件通知功能主要包含两个部分:全局配置和项目配置. 一. 先 ...

  10. 初识javascript变量和基本数据类型

    1.1首先,学习使用firebug控制台.设置一下firefox 中的配置选项,以便使控制台中的javascript警告更为严格...以方便我们更好的找出程序中不必要的bug. 1. 在火狐浏览器fi ...