- 浏览: 36200 次
- 性别:
- 来自: 广州
最近访客 更多访客>>
最新评论
-
charrys:
呵自己跟自己留言
JS可以控制样式的名称写法 -
charrys:
自己顶下
我的json获取数据实例,直接运行就可以看到了
关于图片延迟加载技术的优点与缺点(来自http://www.ok22.org/art_detail.aspx?id=88)
因为工作需要所以最近研究了一下淘宝、QQ、拍拍等几个大型网站的图片延迟加载技术!所以与大家分享一下,仅是代表我的个人观点
图片延迟加载技术(ImageLazyLoad),在页面上图片比较多的时候,打开一张页面必然引起与服务器大数据量的交互。尤其是对于高清晰的图片,占的几M的空间。ImageLazyLoad技术就是,当前可是界面的图片是加载进来的,而不可见页面(通过滚动条下拉可见)中的图片是不加载的,这样势必会引起速度上质的提升。
使用此技术的网站有太多太多,如淘宝,还有一些动漫网站,眼下比较常用的图片延迟加载技术有四种:kissy(淘宝的JS框架),Jquery 图片延迟插件,Prototype,YUI 2。
YUI的图片延迟技术是就成熟的,Jquery的图片延迟插件的设计灵感就来自于YUI的延迟技术(Lazyloader is inspired by YUI ImageLoader Utility by Matt Mlinac),闲话不说,一起来看看如何使用。
- <html xmlns="http://www.w3.org/1999/xhtml">
- <head>
- <title>js延时加载</title>
- <script type="text/javascript">
- lazyLoad = (function () {
- var map_element = {};
- var element_obj = [];
- var download_count = 0;
- var last_offset = -1;
- var doc_body;
- var doc_element;
- var lazy_load_tag;
- function initVar(tags) {
- doc_body = document.body;
- //判断是否为IE的"怪异模式"
- doc_element = document.compatMode == 'BackCompat' ? doc_body : document.documentElement;
- lazy_load_tag = tags || ["img", "iframe"];
- };
- function initElementMap() {
- //var all_element = [];
- //从所有相关元素中找出需要延时加载的元素
- for (var i = 0, len = lazy_load_tag.length; i < len; i++) {
- var el = document.getElementsByTagName(lazy_load_tag[i]);
- for (var j = 0, len2 = el.length; j < len2; j++) {
- if (typeof (el[j]) == "object" && el[j].getAttribute("lazy_src")) {
- element_obj.push(el[j]);
- }
- }
- }
- for (var i = 0, len = element_obj.length; i < len; i++) {
- var o_img = element_obj[i];
- var t_index = getAbsoluteTop(o_img); //得到图片相对document的距上距离
- if (map_element[t_index]) {
- map_element[t_index].push(i);
- } else {
- //按距上距离保存一个队列
- var t_array = [];
- t_array[0] = i;
- map_element[t_index] = t_array;
- download_count++; //需要延时加载的图片数量
- }
- }
- };
- function initDownloadListen() {
- if (!download_count) return;
- var offset = (window.MessageEvent && !document.getBoxObjectFor) ? doc_body.scrollTop : doc_element.scrollTop;
- //可视化区域的高=offtset+document的高
- var visio_offset = offset + doc_element.clientHeight;
- if (last_offset == visio_offset) {
- setTimeout(initDownloadListen, 200);//每隔0.2秒检测一次,这玩意儿感觉有些耗资源的
- return;
- }
- last_offset = visio_offset;
- var visio_height = doc_element.clientHeight;
- var img_show_height = visio_height + offset;
- for (var key in map_element) {
- if (img_show_height > key) {
- var t_o = map_element[key];
- var img_vl = t_o.length;
- for (var l = 0; l < img_vl; l++) {
- element_obj[t_o[l]].src = element_obj[t_o[l]].getAttribute("lazy_src");
- }
- delete map_element[key];
- download_count--;
- }
- }
- setTimeout(initDownloadListen, 200);
- };
- function getAbsoluteTop(element) {
- if (arguments.length != 1 || element == null) {
- return null;
- }
- var offsetTop = element.offsetTop;
- while (elementelement = element.offsetParent) {
- offsetTop += element.offsetTop;
- }
- return offsetTop;
- }
- function init(tags) {
- initVar(tags);
- initElementMap();
- initDownloadListen();
- };
- return {
- init: init
- }
- })();
- </script>
- <style type="text/css">
- img{height:800px}
- </style>
- </head>
- <body>
- <div>
- <img lazy_src="http://pic.vlike.com/girl/UploadFiles_9401/201005/13/2010051307474029890_big.jpg" /><br/>
- <img lazy_src="http://pic.vlike.com/girl/UploadFiles_9401/201005/13/2010051307474372951_big.jpg" /><br/>
- <img lazy_src="http://pic.vlike.com/girl/UploadFiles_9401/201005/06/2010050616595471474_big.jpg" /><br/>
- <img lazy_src="http://pic.vlike.com/girl/UploadFiles_9401/201005/13/2010051307474693772_big.jpg" /><br/>
- <img lazy_src="http://pic.vlike.com/girl/UploadFiles_9401/201005/05/2010050511370456961_big.jpg" /><br/>
- <img lazy_src="http://pic.vlike.com/girl/UploadFiles_9401/201005/13/2010051311000442310_big.jpg" /><br/>
- </div>
- <script type="text/javascript">
- lazyLoad.init();
- </script>
- </body>
- </html>
LazyLoad(延迟加载)技术不仅仅用在对网页中图片的延迟加载,对数据同样可以,Google Reader和Bing图片搜索就把LazyLoad技术运用的淋漓尽致;
但做为技术而言没有十全十美的技术,缺点也是有的:
1.与Ajax技术的冲突;
2.图片的延迟加载,遇到高度特别高的图片,会出现停止加载的问题;
3.写代码不规范的朋友要注意了,不管由于什么原因,如果您的页面中,img标签的height属性未定义,那么我建议您最好不要使用 ImageLazyLoad。
发表评论
-
我的json获取数据实例,直接运行就可以看到了
2011-04-18 10:36 1313开始一直用jq的ajax接收值也是字符但是没用过json数据。 ... -
ckeditor 编辑器+finder配置上传功能
2011-04-03 11:53 1330一、官方Download 1、CKEditor ... -
kindeditor/ckeditor 编辑器加+图片自动上传成功(源码下载)
2011-04-03 11:40 1997编辑器加+图片自动上传并且更新编辑器图片的URL成功完例! ... -
js实现的非跨域的iframe高度自适应(完美兼容IE,FF,Opera)
2011-03-12 16:28 1381iframe的高度一直是让人头疼的问题。今天因为有个项目需要用 ... -
js遮罩层
2011-03-12 15:23 796直接贴代码了!(来自:http://www.ok22.org/ ... -
js多Tab自动切换,带完善的鼠标事件
2011-03-01 09:31 1565js多Tab自动切换,带完善的鼠标事件! 说明:打开鼠标时 ... -
js多个tab切换简单不需要在body内添加事件
2011-02-15 17:20 1335注意的是a的里面的rel属性window.onload事件!在 ... -
js文字上下滚动+左右滚动兼容FF/IE
2011-02-15 11:07 1789我也是最近因为要做这 ... -
前端设计js+Tab切换可关闭+添加并自动判断是否已打开自动切换当前状态
2011-02-14 15:59 1338看了很多别人写的tab切换效果感觉都只是div+js去切换已存 ... -
清空数组的两种方式
2011-02-09 16:58 2271方式一,length赋值为0 这种方式很有意思,其它语言 ... -
js时间倒计时
2011-01-06 11:26 869前断时间,因为需要 ... -
JS可以控制样式的名称写法
2011-01-06 11:19 1016盒子标签和属性对照 CSS语法 (不区分大小写) ... -
js给C#控件赋值
2010-12-30 10:34 1777前台代码 Html代码 <%@ Pa ... -
iframe里面的页面调用父窗口,左右窗口js函数的方法
2010-12-30 10:33 1215iframe里面的页面调用父窗口,左右窗口js函数的方法 ... -
js判断父页存在
2010-12-30 10:26 827当你有多个页面有iframe内页时,你肯定也不想别人直接打开子 ...
相关推荐
图片延迟加载(Image Lazy Load)是一种优化网页性能的技术,它主要应用于含有大量图片的页面,以提高页面加载速度和用户体验。这种技术的核心思想是只在图片实际需要显示时(即进入用户视口)才进行加载,而不是一...
2.当然了你也可以通过设置占位符图片和自定事件来触发加载图片事件 $("img").lazyload({ placeholder : "img/grey.gif", event : "click" }); 3.可以通过定义effect 参数来定义一些图片显示效果 $("img")...
其中,图片延迟加载技术是一种有效提高网页加载速度的技术,通过延迟非可视区域内图片的加载来减轻服务器负担,并提升用户的浏览体验。本文将详细介绍如何利用jQuery框架来实现图片延迟加载功能。 #### 二、jQuery...
// 清除body上的data-imageLazyload属性,以便重新加载图片 document.body.removeAttribute('data-imageLazyload'); // 重新调用imageLazyload,传入配置项 mui(document).imageLazyload({ placeholder: '../../...
ImageLazyLoad 技术是一种优化网页性能的方法,它只加载当前可视区域内的图片,而非一次性加载所有图片。当用户滚动页面,即将进入视口的图片才会开始加载。这种方式可以显著提高网页加载速度,特别是在高分辨率或大...
在图片加载时均采用了一种名为懒加载的方式,具体表现为,当页面被请求时,只加载可视区域的图片,其它部分的图片则不加载src="...
lazyLoad懒加载技术应用实例,适用于图片多的网站。...这里要实现的功能:可见页面的图片是加载的,而不可见页面通过滚动条下拉可见,这也叫做“ImageLazyLoad技术”,需要用到延迟加载的jQuery插件