教程集 www.jiaochengji.com
教程集 >  jQuery  >  jquery 教程  >  正文 JQuery 图片延迟加载并等比缩放插件

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

发布时间:2013-09-07   编辑:jiaochengji.com
图片延迟加载并等比缩放,一个简单的JQuery插件。 需要的朋友可以参考下。
图片延迟加载并等比缩放,一个简单的jquery插件。 需要的朋友可以参考下。 最近在学习JS的OOP所以写了这么个东西
使用方法:
$(".viewArea img").zoom({height:74,width:103});
效果演示:
http://demo.jb51.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);

效果是这样的:

您可能感兴趣的文章:
JQuery 图片延迟加载并等比缩放插件
jquery.lazyload 实现图片延迟加载jquery插件
使用jquery插件实现图片延迟加载技术详细说明
基于jquery的lazy loader插件实现图片的延迟加载[简单使用]
Lazy Load 延迟加载图片的 jQuery 插件
jQuery lazyLoad图片延迟加载插件的优化改造方法分享
jquery图片延迟加载 前端开发技能必备系列
jQuery条目展示插件 Easy Paginate
jquery 图片预加载 自动等比例缩放插件
jQuery图片预加载(延迟加载)插件Lazy Load

[关闭]
~ ~