热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

jQuery图片预加载+等比例缩放

本文介绍了使用jQuery实现图片预加载和等比例缩放的方法,同时提供了演示和相关代码。该方法可以重置图片的宽度和高度,并使图片在水平和垂直方向上居中显示。

演示:
http://www.cssrain.cn/demo/imgResizeCenter/demo.html

相关代码:
/*
* jQuery插件:
* 图片预加载
* 重置图片宽度,高度
* 图片水平,垂直居中
* Dev By CssRain.cn
*/
jQuery.fn.loadthumb = function(options) {
    options = $.extend({
         src : "",
         imgId : "myImgs",
         parentId : "CRviewer"
    },options);
    var _self = this;
    _self.hide();
    var img = new Image();
    $(img).load(function(){
        imgDem = {};
        imgDem.w  = img.width;
        imgDem.h  = img.height;
        imgDem = $.imgResize({"w": $("#"+options.parentId).width() ,"h": $("#"+options.parentId).height()},{"w":imgDem.w,"h":imgDem.h});
        var imgMargins = $.imgCenter({"w": $("#"+options.parentId).width() ,"h": $("#"+options.parentId).height()},{"w":imgDem.w,"h":imgDem.h});
        $("#"+options.imgId).css({width:imgDem.w,height:imgDem.h,marginLeft:imgMargins.l,marginTop:imgMargins.t});
        _self.attr("src", options.src);
        _self.fadeIn("slow");
    }).attr("src", options.src);  //.atte("src",options.src)要放在load后面,
    return _self;
}
//重置图片宽度,高度插件 ( parentDem是父元素,imgDem是图片 )
jQuery.imgResize = function(parentDem,imgDem){
    if(imgDem.w>0 && imgDem.h>0){
        var rate = (parentDem.w/imgDem.w         //如果 指定高度/图片高度  小于  指定宽度/图片宽度 ,  那么,我们的比例数 取 指定高度/图片高度。
        //如果 指定高度/图片高度  大于  指定宽度/图片宽度 ,  那么,我们的比例数 取 指定宽度/图片宽度。
        if(rate <&#61; 1){  
            imgDem.w &#61; imgDem.w*rate; //图片新的宽度 &#61; 宽度 * 比例数
            imgDem.h &#61; imgDem.h*rate;
        }else{//  如果比例数大于1&#xff0c;则新的宽度等于以前的宽度。
            imgDem.w &#61; imgDem.w;
            imgDem.h &#61; imgDem.h;
        }
    }
    return imgDem;
}
//使图片在父元素内水平&#xff0c;垂直居中&#xff0c;( parentDem是父元素&#xff0c;imgDem是图片 )
jQuery.imgCenter &#61; function(parentDem,imgDem){
    var left &#61; (parentDem.w - imgDem.w)*0.5;
    var top &#61; (parentDem.h - imgDem.h)*0.5;
    return { "l": left , "t": top};
}

下载&#xff1a;
http://www.cssrain.cn/demo/imgResizeCenter/imgResize.rar

转:https://www.cnblogs.com/lidingwen/archive/2010/12/31/1922741.html



推荐阅读
author-avatar
Durston
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有