JavaScript之图片懒加载的实现
图片懒加载指的是在浏览过程中随着需要才被加载出来,例如某宝上面浏览商品时,会伴随很多的图片,如果一次全部加载出来的话,显然资源有些浪费,并且加载速度也会相对降低,那么懒加载的实现很重要。即随着浏览翻阅时,下面的图片才被加载出来,这样又不浪费带宽,访问网页速度也很快,用户体验也会有所提升。
说了这么多,其实所需要注意的要点有:
- 屏幕可视区域的高度
- 每张图片在文档中的高度
- 图片符合要求进行加载时,将图片地址赋值给属性 src
- 对屏幕滚动事件进行监控
- 首次进入网页未滑动屏幕时要显示的图片
代码如下:
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>图片懒加载实现</title>
<style>
img{
width: 300px;
}
</style>
</head>
<body>
<div>
<p><img src="" data-original="./Saved Pictures/shawu.jpg" /></p>
<p><img src="" data-original="./Saved Pictures/ass.jpg" /></p>
<p><img src="" data-original="./Saved Pictures/LmLm.jpg" /></p>
<p><img src="" data-original="./Saved Pictures/和服.jpg" /></p>
<p><img src="" data-original="./Saved Pictures/花亭.jpg" /></p>
<p><img src="" data-original="./Saved Pictures/康娜.jpg" /></p>
<p><img src="" data-original="./Saved Pictures/初音未来.jpg" /></p>
<p><img src="" data-original="./Saved Pictures/红发少女.jpg" /></p>
<p><img src="" data-original="./Saved Pictures/shawu.jpg" /></p>
<p><img src="" data-original="./Saved Pictures/ass.jpg" /></p>
<p><img src="" data-original="./Saved Pictures/LmLm.jpg" /></p>
<p><img src="" data-original="./Saved Pictures/和服.jpg" /></p>
<p><img src="" data-original="./Saved Pictures/花亭.jpg" /></p>
<p><img src="" data-original="./Saved Pictures/康娜.jpg" /></p>
<p><img src="" data-original="./Saved Pictures/初音未来.jpg" /></p>
<p><img src="" data-original="./Saved Pictures/红发少女.jpg" /></p>
<p><img src="" data-original="./Saved Pictures/shawu.jpg" /></p>
<p><img src="" data-original="./Saved Pictures/ass.jpg" /></p>
<p><img src="" data-original="./Saved Pictures/LmLm.jpg" /></p>
<p><img src="" data-original="./Saved Pictures/和服.jpg" /></p>
<p><img src="" data-original="./Saved Pictures/花亭.jpg" /></p>
<p><img src="" data-original="./Saved Pictures/康娜.jpg" /></p>
<p><img src="" data-original="./Saved Pictures/初音未来.jpg" /></p>
<p><img src="" data-original="./Saved Pictures/红发少女.jpg" /></p> </div>
<script src="jquery-3.2.1.slim.js"></script>
<script>
var wHeight=$(window).height(); //获取屏幕可视高度
$('img').each(function () { //对图片进行循环
var ownHeight=$(this).offset().top; //获取当前图片在文档中的位置
if(ownHeight<=wHeight){ //如果当前图片位置在屏幕可视范围之内加载此图片
$(this).attr('src',$(this).attr('data-original'));
}
}); $(window).on('scroll',function(){ //添加屏幕滚动事件
$('img').each(function () {
var hasSorollTop=$(window).scrollTop(); //获取屏幕已滚动高度
var ownHeight=$(this).offset().top;
if(ownHeight<=(hasSorollTop+wHeight+500)){
//当图片在屏幕滚动时,距离可视区域500像素时加载此图片,
// 以保证查看此图时,下面的一张以提前加载完成
$(this).attr('src',$(this).attr('data-original'));
}
});
});
</script>
</body>
</html>
在进行JavaScript练习时,不要一下将代码写完,每进行一步要对其进行测试一下,不然到最后哪里出现错误修改起来相对比较麻烦。
原创不易,尊重版权。转载请注明出处:http://www.cnblogs.com/xsmile/
JavaScript之图片懒加载的实现的更多相关文章
- 基于javascript实现图片懒加载(亲测有效)
这篇文章主要介绍了javascript实现图片懒加载的方法及思路,有时我们需要用懒加载,也就是延迟加载图片的方式,来提高网站的亲和力,需要的朋友可以参考下! 一.定义 图片延迟加载也称为懒加载,延迟加 ...
- javascript原生图片懒加载
一,原生javascript图片懒加载 1. 使用方法,例如 // 要绑定的图片地址 <img data-src={url} alt=" "> 2. 在页面中引入下列原 ...
- 插件:★★★ !!!图片懒加载 lazyload.js 、 jquery.scrollLoading.js
插件:图片懒加载 jquery.lazyload.js 2016-3-31 插件说明:http://www.w3cways.com/1765.html (小插件,好用) 下载地址: https://r ...
- javascript图片懒加载与预加载的分析
javascript图片懒加载与预加载的分析 懒加载与预加载的基本概念. 懒加载也叫延迟加载:前一篇文章有介绍:JS图片延迟加载 延迟加载图片或符合某些条件时才加载某些图片. 预加载:提前加载图片, ...
- js, javascript 图片懒加载 实例代码
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&quo ...
- JavaScript——图片懒加载
前言 有一个朋友问我这个问题,刚好有时间,现在就简单的写个Demo~ github | https://github.com/wangyang0210/bky/tree/picLoadLazy 内容 ...
- JS图片懒加载
简介 当页面图片太多时,加载速度就会很慢.尤其是用2G/3G/4G访问页面,不仅页面慢,而且还会用掉很多流量.图片懒加载的原理就是将页面内所有需要加载的图片全部换成一张默认的图片(一般尺寸很小),只有 ...
- 图片懒加载插件lazyload使用方法
图片懒加载插件lazyload使用方法 一.如何使用: Lazy Load 依赖于 jQuery.引入文件 <script type="text/javascript" sr ...
- 前端性能优化--图片懒加载(lazyload image)
话说前头: 上次写了一篇webpack的学习心得,webpack能做到提升前端的性能,其模块打包最终生成一个或少量的文件能够减少对服务端的请求.除此之外,本次的图片懒加载(当然不仅限于图片,还可以有视 ...
随机推荐
- InnoDB锁
共享锁和排它锁 InnoDB实现了标准的行级锁,包括两种类型:共享锁(S)和排它锁(X) 一个共享锁(S)允许事务持有这种锁来读取一行 一个排它锁(X)允许事务持有这种锁来修改或删除一行 如果事务T1 ...
- MySQL 5.7 InnoDB缓冲池NUMA功能支持——但是别高兴的太早
当前CPU都已是NUMA架构,相信除了历史遗留系统,很少会有数据库跑在SMP的CPU上了.NUMA架构带来的优势无言而语,CPU更快的内存访问速度,但是带来的问题也不言而喻,特别是对于数据库的影响.M ...
- Java的参数传递是值传递还是引用传递
当一个对象被当作参数传递到一个方法后,在此方法内可以改变这个对象的属性,那么这里到底是值传递还是引用传递? 答:是值传递.Java 语言的参数传递只有值传递.当一个对象实例作为一个参数被传递到方法中 ...
- Django date__range([start,end])其中不包括end时间
# date__range([start,end]) # 不包括end时间,需转换最后的截止时间 from datetime import datetime, timedelta new_end = ...
- 提取微信小程序“头脑王者”业务逻辑
产品经理今天让我整理微信小程序"头脑王者"的产品逻辑,花了一天时间在XMind写了写,整理后的内容如图,分享给大家希望大家可以多多点评,互相学习,不知道应该写什么,重要的内容都在图 ...
- 微信小程序demo-环球小镇
微信小程序-环球小镇说明:实现了环球小镇(huanqiuxiaozhen.com)移动端商城客户端部分功能,包括首页,分类,购物车,帐户,品牌列表,商品详情等功能. 项目下载:http://bb ...
- 关于python使用threadpool中的函数单个参数和多个参数用法举例
1.对单个元素的函数使用线程池: # encoding:utf-8 __author__='xijun.gong' import threadpool def func(name): print 'h ...
- burpsuite截断绕过前端限制上传一句话
设置代理,这里就不说了 打开上传界面 burpsuite开启拦截,上传lurp.hpg 在burp找到上传文件的格式改回原来一句话的格式 上传= =
- 枚举 输入流重载>> C++
语言:C++ 我们可能会遇到这种情况:自己定义了一个枚举类型,但是却不知道如何重载输入流,使我们定义的枚举用起来不是很方便. 那么,如何去重载呢,我们先来看一下内置类型的测试过程: #include& ...
- x+y=xy
有一天,我拿这一本本子给两位同学看,问他们这本本子多少钱,一个说3块,一个说1.5块,但它实际上是4.5块.于是,我们发现,3X1.5=4.5,3+1.5=4.5.那么这样的数有哪些呢? ...