加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 综合聚焦 > 资源网站 > 资源 > 正文

基于jQuery的图片大小自动适应实现代码

发布时间:2020-12-14 22:18:12 所属栏目:资源 来源:网络整理
导读:关于 这个和以前弄的图片远处放大有许多相同的地方,比如图片预加载、有限容器显示无限大图片。 大小计算:内外两个比例。 复制代码 代码如下: // 容器比例和图片比例 var dr = dw/dh,ir = iw/ih; if(drir){ ih = dh; iw = ih * ir; }else{ iw = dw; ih = iw
关于
这个和以前弄的图片远处放大有许多相同的地方,比如图片预加载、有限容器显示无限大图片。

大小计算:内外两个比例。
复制代码 代码如下:

// 容器比例和图片比例
var dr = dw/dh,ir = iw/ih;
if(dr>ir){
ih = dh; iw = ih * ir;
}else{
iw = dw; ih = iw / ir;
}

居中显示:CSS绝对定位,负边距。
复制代码 代码如下:

$img.css({width:iw,height:ih,position:'absolute',top:'50%',left:'50%',marginLeft:-iw/2,marginTop:-ih/2})

加载中和加载出错:可自定义的参数。

HTML容器:
<div class="jq-img-autoresize" data-img-size="160,390" data-img-url="m1.jpg"></div>

如何使用:
复制代码 代码如下:

$('div.jq-img-autoresize').imgAutoResizer({
loading : function () { $(this).text('loading..'); }
,error : function () { $(this).text('无效..'); }
});

所有代码:
复制代码 代码如下:

/*
* 图片等比缩放
* @by ambar
* @create 2010-11-17
* @update 2010-11-17
*/
$.fn.imgAutoResizer = function (options) {
return this.each(function () {
var opt = $.extend({
sizeAttr : 'data-img-size'
,srcAttr : 'data-img-url'
,error : null
,loading : null
},options || {});
var $el = $(this),src = $el.attr(opt.srcAttr),size = $el.attr(opt.sizeAttr).split(',');
// 容器宽高
var dw = size[0],dh = size[1];
var $img = $('<img />',{ src : src }),img = $img[0];
var autoresize = function () {
if($el.data('img.complete')) return;
// 图片宽高
var iw = img.width,ih = img.height;
if(!iw || !ih) return;
// 比例
var dr = dw/dh,ir = iw/ih;
if( !(dw > iw && dh > ih) ){
if(dr>ir){
ih = dh; iw = ih * ir;
}else{
iw = dw; ih = iw / ir;
}
}
// console.log(dr,':',iw,'@',ih);
$el.data('img.complete',true).css({position:'relative',width:dw,height:dh,overflow:'hidden'});
$img.css({width:iw,marginTop:-ih/2}).appendTo($el.empty());
};
$img
.load(autoresize)
.error(function () {
if($.isFunction(opt.error)) opt.error.call($el);
});
if(img.complete){
if(img.width && img.height) autoresize();
}else{
if($.isFunction(opt.loading)) opt.loading.call($el);
}
})
};

演示地址:http://demo.aspzz.cn/js/imgAutoResizer/
打包下载:http://xiazai.aspzz.cn/201011/yuanma/imgAutoResizer.rar

您可能感兴趣的文章:

  • 使用jQuery实现验证上传图片的格式与大小
  • jQuery获取file控件中图片的宽高与大小
  • 基于jquery实现图片相关操作(重绘、获取尺寸、调整大小、缩放)
  • jquery预览图片实现鼠标放上去显示实际大小
  • jQuery实现的上传图片本地预览效果简单示例
  • 简单实现jQuery上传图片显示预览功能
  • JQuery Jcrop 实现图片裁剪的插件
  • jquery实现图片上传前本地预览功能
  • 基于Jquery的简单图片切换效果
  • 使用jquery获取网页中图片高度的两种方法
  • jQuery实现判断上传图片类型和大小的方法示例

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读