JQuery 图片延迟加载并等比缩放插件


最近在学习JS的OOP所以写了这么个东西
使用方法:
$(".viewArea img").zoom({height:74,width:103});
效果演示:
http://demo.phpstudy.net/html/jquery_img/jquery_img.htm
代码:

复制代码 代码如下:

(function($){
$.fn.zoom = function(settings){
//一些默认配置;
settings = $.extend({
height:0,
width:0,
loading:"lightbox-ico-loading.gif"
},settings);
var images = this;
$(images).hide();
var loadding = new Image();
loadding.className="loadding"
loadding.src = settings.loading;
$(images).after(loadding);
//预加载
var preLoad = function($this){
var img = new Image();
img.src = $this.src;
if (img.complete) {
processImg.call($this);
return;
}
//$this.src = loadding.src;//会导致获取错误的尺寸
img.onload = function(){
//$this.src = this.src; //会导致获取错误的尺寸
processImg.call($this);
img.onload=function(){};
}
}
//计算图片尺寸;
function processImg(){
//if(settings.height===0||settings.width ===0) return;
var m = this.height-settings.height;
var n = this.width - settings.width;
if(m>n)
this.height = this.height>settings.height ? settings.height :
this.height;
else
this.width = this.width >settings.width ? settings.width :
this.width;
$(this).next(".loadding").remove()
$(this).show();
}
return $(images).each(function(){
preLoad(this);
});
}
})(jQuery);

效果是这样的:



相关阅读:
PHP中用接口、抽象类、普通基类实现“面向接口编程”与“耦合方法”简述
增加MT MTOnThisDay插件 - 显示历史记录
XslCompiledTransform类引起的"内存泄漏"问题
PHP:招PHP高级工程师的面试题
一步一步教你写淡入淡出带注释的图片轮播插件(一)
用网页也能远程修改Win2003计算机名称
Marquee标记在XHTML代码中该如何用
FreeBSD如何跑diskless
Js仿新浪微博首页内容滚动
css 有弹动效果的网页导航
关于MySQL编码问题的经验总结
SQLServer备份的三个恢复模型
网站进行W3C XHTML1.0验证的经验
JS教程:判断滚轮滚动方向在各个浏览器中的表现
快速导航

Copyright © 2016 phpStudy |