第一个轮子wlazyload插件。为了解决自己系统里面图片懒加载的简单插件
来源:互联网 发布:陈涌海 知乎 编辑:程序博客网 时间:2024/04/28 16:02
网上有lazyload的完整插件,但是用在我们系统里面总是有bug,所以,我觉得是他插件里面关于元素top值计算有问题,那么这么想就说干脆自己做一个简单的lazyloady插件吧,取名子wlazyload。
;(function($){$.fn.wlazyload= function(option){function getPageScroll() { var xScroll, yScroll; if (self.pageYOffset) { yScroll = self.pageYOffset; xScroll = self.pageXOffset; } else if (document.documentElement && document.documentElement.scrollTop) { yScroll = document.documentElement.scrollTop; xScroll = document.documentElement.scrollLeft; } else if (document.body) { yScroll = document.body.scrollTop; xScroll = document.body.scrollLeft; } function getscroll(lol,dota){ this.xscroll=lol; this.yscroll=dota; } arrayPageScroll = new getscroll(xScroll,yScroll) return arrayPageScroll;};function caltop(vrobj){var vtop=vrobj.offsetHeight;while(vrobj.offsetParent){vtop+= vrobj.offsetTop;vrobj = vrobj.offsetParent;} return vtop;}var gglazy=getPageScroll();var screenheight=$(window).height();var lazydata = {lazyheight:100,screenheight:screenheight}var that=this;var options = $.extend(lazydata, option);this.each(function(){if(caltop(this)-gglazy.yscroll-options.screenheight<options.lazyheight && this.getAttribute("src")==undefined ){this.src= this.getAttribute("data-origin");}return gglazy;});document.onscroll=function(){gglazy=getPageScroll();that.each(function(){if(caltop(this)-gglazy.yscroll-options.screenheight<options.lazyheight && this.getAttribute("src")==undefined ){this.src= this.getAttribute("data-origin");}return gglazy;});console.log('123');}}})(jQuery);
上面就是我的插件的源码,但是我总是觉得在插件内部定义一个document.onscroll事件会影响性能。那么这个插件很简单,传入的参数有限。现在传一个lazyheight,表示当页面的图片距离浏览器的下方的位置lazyheight出开始加载。
使用方式
$('img').wlazyload();
当然,也可以设置参数
$('img').wlazyload({'lazyheight':200+'px'})
目前只加了一个功能,就是懒加载的基本功能,后续完善插件再来跟新,希望有高手能指出代码如何去优化。
1 0
- 第一个轮子wlazyload插件。为了解决自己系统里面图片懒加载的简单插件
- 完成了自己第一个jQuery的插件NumberText 1.0
- 图片懒加载插件
- 【轮子介绍】android图片加载库:Glide的简单介绍
- jquery懒加载图片的插件 jquery懒加载图片的插件
- 图片懒加载插件技术
- 插件推荐Echo.js 简单易用的图片延迟加载插件
- 第一个jquery插件
- 自己写个vue.js插件(3):插件里面包含子组件
- eclipse的第一个struts2插件
- WelcomeHome - 你的第一个ACE2插件
- 我的第一个JQUERY 插件 tree3
- 我写的第一个Mootools插件
- weiphp-我的第一个插件
- 图片预加载插件
- 自己写jquery.lazyloading图片延迟加载插件,通用
- 写个自己的Xcode4插件
- 自己写出个ajax的分页插件
- sublime text3 安装C语言插件
- ADB高级应用
- PHP数据结构之三 线性表中的单链表的PHP实现
- EBImage中文文档
- 如何编写高质量的测试用例
- 第一个轮子wlazyload插件。为了解决自己系统里面图片懒加载的简单插件
- 课堂笔记2016.8.2
- 【记录】u-boot中添加命令
- RX操作符之错误处理(catch[onErrorReturn、onErrorResumeNext、onExceptionResumeNext]、retry、retryWhen)
- Spring事务传播性与隔离级别
- 关于android开发时,发生Error infalting classa com.baidu.mapapi.map.MapView的解决办法
- 九度OJ 1111 单词替换
- Opencv中对查找表LUT的使用与理解
- laravel 一 搭建环境(mac)Composer下载安装laravel