用canvas实现图片的懒加载并且下滑到据底部60px的时候再次加载数据,模仿UC浏览器的新闻加载。

  完整代码:https://github.com/dirkhe1051931999/writeBlog/tree/master/canvasloadimg

  html结构
<section class="productul" id="productul">
<input type="hidden" id="pagenumlength" value="1">
<ul id="scrollAdd">
<li>
<a href="#">
<div class="leftimage fl">
<canvas data-src="./product1.png"></canvas>
</div>
<div class="productcontent fr">
<p class="ptitle ">这是标题</p>
<p class="pdes ">简介简介简介简介简介简介简介简介简介简介简介简介简介简介</p>
<p class="pprice ">这是注释</p>
</div>
</a>
</li>
<li>
<a href="#">
<div class="leftimage fl">
<canvas data-src="./product1.png"></canvas>
</div>
<div class="productcontent fr">
<p class="ptitle ">这是标题</p>
<p class="pdes ">简介简介简介简介简介简介简介简介简介简介简介简介简介简介</p>
<p class="pprice ">这是注释</p>
</div>
</a>
</li>
<li>
<a href="#">
<div class="leftimage fl">
<canvas data-src="./product1.png"></canvas>
</div>
<div class="productcontent fr">
<p class="ptitle ">这是标题</p>
<p class="pdes ">简介简介简介简介简介简介简介简介简介简介简介简介简介简介</p>
<p class="pprice ">这是注释</p>
</div>
</a>
</li>
</ul>
<div class="loaddiv"></div>
</section>
  方法
var ajaxState = true,
pageSize = 5,
currentpage =1;
// canvas懒加载
function loadCanvas () {
var imglength = $("#productul").find("canvas").length;
if (imglength>0) {
$("#productul").find("canvas").each(function(){
var imgSrc=$(this).data("src");
var imageObj = new Image();
// 当前获取的canvas
imageObj.canvs = $(this)[0];
var cvs = imageObj.canvs.getContext("2d");
if (cvs) {
imageObj.onload = function(){
imageObj.canvs.width = this.width;
imageObj.canvs.height = this.height;
cvs.drawImage(this,0,0);
// 绘制成功后 把loading取消
$(imageObj.canvs).css("background-image","none");
}
imageObj.src=imgSrc;
}
})
}
}
// ajax请求数据(模拟了一个接口)
function getData(pagenumber){
$.ajax({
type:"get",
url:"./test.json",
data:{
page:pagenumber,
row:pageSize,
},
dataType:"json",
success:function(result){
$(".loaddiv").hide();
if (result.length>0) {
// 数据加载成功,设置标志位
ajaxState=true;
insertDiv(result);
loadCanvas();
}else{
// 没有数据,不执行,设置标志位
$("#pagenumberlength").val("0");
}
},
beforeSend:function(){
$(".loaddiv").show();
},
error:function(){
$(".loaddiv").hide();
}
})
}
// dom 插入
function insertDiv(json){
var $mainDiv = $("#scrollAdd");
var html = "";
var showlength =5;
if (json.length<5) {
showlength = json.length;
}
for(var i=0;i<showlength;i++){
html += '<li><a href="#">'+
'<div class="leftimage fl"><canvas data-src="./product1.png" ></canvas></div>'+
'<div class="productcontent fr">'+
'<p class="ptitle ">这是标题</p>'+
'<p class="pdes ">简介简介简介简介简介简介简介简介简介简介简介简介简介简介</p>'+
'<p class="pprice ">这是注释</p>'+
'</div></a></li>';
}
$mainDiv.append(html);
}
// 据底部60判断
function scrollHandler(){
// console.log(parseInt(scrollT)+parseInt(winHeight)+50>=parseInt(pageH) && ajaxState) var pageH = $(document).height();
// 滚动条的top
var scrollT = $(window).scrollTop();
var winHeight = $(window).height();
if (parseInt(scrollT)+parseInt(winHeight)+60>=parseInt(pageH) && ajaxState){
if ($("#pagenumlength").val()=="1") {
// 滚动到底部,设置标志位
ajaxState =false;
currentpage++;
getData(currentpage);
}else{
return;
}
}
}
  执行代码
    $(function(){
loadCanvas();
$(window).scroll(scrollHandler);
$("#productul").on("touchmove",scrollHandler);
})

  注意:$(document).height() = $(window).height() + $(window).scrollTop()

      其中$(document).height()是网页高度, $(window).height()是可视窗口高度,$(window).scrollTop()是可视窗口距顶端高度

  

学习 | canvas实现图片懒加载 && 下滑底部加载的更多相关文章

  1. 前端性能优化--图片懒加载(lazyload image)

    话说前头: 上次写了一篇webpack的学习心得,webpack能做到提升前端的性能,其模块打包最终生成一个或少量的文件能够减少对服务端的请求.除此之外,本次的图片懒加载(当然不仅限于图片,还可以有视 ...

  2. 原生js开发,无依赖、轻量级的现代浏览器图片懒加载插件,适合在移动端开发使用

    优势 1.原生js开发,不依赖任何框架或库 2.支持将各种宽高不一致的图片,自动剪切成默认图片的宽高 比如说你的默认图片是一张正方形的图片,则各种宽度高度不一样的图片,自动剪切成正方形. 完美解决移动 ...

  3. JavaScript——图片懒加载

    前言 有一个朋友问我这个问题,刚好有时间,现在就简单的写个Demo~ github | https://github.com/wangyang0210/bky/tree/picLoadLazy 内容 ...

  4. 原生js实现图片懒加载+加入节流

    这两天在学习图片的懒加载实现,看了很多大佬的博客,终于有了点成果.现在用了其中一位大佬的文章中的代码实现了图片懒加载并且在其基础上加入了节流函数. 原理就不多讲了,有需要的可以去大佬的文章看看.大佬文 ...

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

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

  6. 学习EF之贪懒加载和延迟加载(2)

    通过昨天对EF贪婪加载和延迟加载的学习,不难发现,延迟加载还是很好用的,但是问题也就来了,有的时候我们只需要加载一个实体,不需要和他相关的外部实体,这时候我们来看看EF延迟加载时怎么作用的吧 打开pr ...

  7. 前端实现图片懒加载(lazyload)的两种方式

    在实际的项目开发中,我们通常会遇见这样的场景:一个页面有很多图片,而首屏出现的图片大概就一两张,那么我们还要一次性把所有图片都加载出来吗?显然这是愚蠢的,不仅影响页面渲染速度,还浪费带宽.这也就是们通 ...

  8. jquery实现简单瀑布流布局(续):图片懒加载

    # jquery实现简单瀑布流布局(续):图片懒加载 这篇文章是jquery实现简单瀑布流布局思想的小小扩展.代码基于前作的代码继续完善. 图片懒加载就是符合某些条件时才触发图片的加载.最常见的具体表 ...

  9. webapp图片懒加载实现

    图片懒加载在webapp上非常流行,应用的很广泛. 实现图片懒加载功能:zepto.picLazyLoad.min.js 引入类库 <script src="1.1.3/zepto.m ...

随机推荐

  1. 土地购买 (斜率优化dp)

    土地购买 (斜率优化dp) 题目描述 农夫 \(John\) 准备扩大他的农场,他正在考虑$ N(1 \leqslant N \leqslant 50,000)$ 块长方形的土地. 每块土地的长宽满足 ...

  2. Mybatis进阶使用-一级缓存与二级缓存

    简介 缓存是一般的ORM 框架都会提供的功能,目的就是提升查询的效率和减少数据库的压力.跟Hibernate 一样,MyBatis 也有一级缓存和二级缓存,并且预留了集成第三方缓存的接口. 一级缓存 ...

  3. kubectl 安装

    下载kubectl二进制文件curl -LO https://storage.googleapis.com/kubernetes-release/release/v1.10.0/bin/linux/a ...

  4. IA-32/centos7开机流程

    开机后系统首先在实地址模式下工作(只有1MB的寻址空间) 开机过程中,需要先准备在实模式下的中断向量表和中断服务程序.通常,由固化在主板上一块ROM芯片中的BIOS程序完成 加载BIOS的硬件信息,B ...

  5. 团队作业3:需求改进&系统设计(歪瑞古德小队)

    目录 一.需求&原型改进 1.1 用户需求调查 1.2 选题需求改进 1.3 功能分析的四个象限 1.4 完善需求规格说明书 1.5 任务分解WBS调整 1.6 项目进度计划调整 二.后端架构 ...

  6. .net core 中的经典设计模式的应用

    .net core 中的经典设计模式的应用 Intro 前段时间我们介绍了23种设计模式,今天来分享一下 asp.net core 种我觉得比较典型的设计模式的应用 实例 责任链模式 asp.net ...

  7. Mybatis动态语句

    If元素If元素是简单的条件判断逻辑,满足制定条件时追加if元素的SQL,不满足条件时不追加,使用格式如下: <select ….> SQL语句1 <if test=“条件表达式”& ...

  8. muduo源码解析3-currentthread命名空间

    CurrentThread 作用: CurrentThread并不是一个类,而是一个命名空间,在mymuduo内部,目的是提供对于当前线程的管理操作. 内部变量: __thread int t_cac ...

  9. 微信商户H5支付申请不通过被驳回解法,拒绝提示:网站有不实内容或不安全信息

    H5支付是指商户在微信客户端外的移动端网页展示商品或服务,用户在前述页面确认使用微信支付时,商户发起本服务呼起微信客户端进行支付.主要用于触屏版的手机浏览器请求微信支付的场景.可以方便从外部浏览器唤起 ...

  10. 【趣味设计模式系列】之【代理模式4--ASM框架解析】

    1. 简介 ASM是assemble英文的简称,中文名为汇编,官方地址https://asm.ow2.io/,下面是官方的一段英文简介: ASM is an all purpose Java byte ...