基于jQuery的图片不完全按比例自动缩小


Posted in Javascript onJuly 11, 2014

举例来说

第一种情况:如图片大小为 600×350,显示区域大小为 200×140,如果图片根据目标宽度(200)按比例缩放后大小变成 116,那么显示在 200×140 就会很难看。如下图左

第二种情况:刚好相反,如图片大小为400×400,显示区域同样是200×140,如果图片根据目标高度(140)按比例缩放后大小变成 140,即 140×140,同样难看。如下图右

 基于jQuery的图片不完全按比例自动缩小  基于jQuery的图片不完全按比例自动缩小

这时用 jQuery 获取图片大小再判断处理一下就稍微好点:如第一种情况按140高度算出宽度 140×600/350=240,然后图片按240×140显示,多余部分用 css 的 overflow:hidden 隐藏。

下面是我的处理方法:(注意 - 这里所说的是原图片宽高都大于目标显示框大小的情况下——所以才叫缩小)

Demo 》这里

Html 部分

假如显示区域的 class 为 thumbnail

<div id="content">

 <div class="thumbnail"><img src="" alt="" /></div>

</div>

css 部分

.thumbnail{overflow:hidden;width:200px;height:140px;}

jQuery 部分

1. 当然是先挂 jQuery 库了,怎样挂自行Google、百度
2. 核心代码

jQuery(document).ready(function(){
/* 图片不完全按比例自动缩小 by zwwooooo */
  $(window).load(function(){
	$('#content div.thumbnail img').each(function(){
		var x = 200; //填入目标图片宽度
		var y = 140; //填入目标图片高度
		var w=$(this).width(), h=$(this).height();//获取图片宽度、高度
		if (w > x) { //图片宽度大于目标宽度时
			var w_original=w, h_original=h;
			h = h * (x / w); //根据目标宽度按比例算出高度
			w = x; //宽度等于预定宽度
			if (h < y) { //如果按比例缩小后的高度小于预定高度时
				w = w_original * (y / h_original); //按目标高度重新计算宽度
				h = y; //高度等于预定高度
			}
		}
		$(this).attr({width:w,height:h});
	});
  });
});

适用场所:固定大小的图片显示区域,如缩略图。

折腾完。

下面推荐个内容页面中常用图片大小控制代码:

<script type="text/javascript">
$(window).load(function() {  
  $(".cont img").each( function() {
 var maxwidth = 800;
 if ($(this).width() > maxwidth) {
  $(this).width(maxwidth);
 }
}); 
}); 
</script>

代码不用解释,值得注意的是两个地方:

第一:$(window).load(function() { 

声明事件的部分使用$(window).load,不能使用$(document).ready。
我在百度和iteye网站看到有相关的文章,方法都是错误的。根本不起作用。

第二:$(".cont img").each( function()

这里是.each( function() { ....  }),each在这里是对指定的图片集合对象逐一调用下面的方法。

这种方法兼容大部分的浏览器,效果也很便捷。

个人感觉这种方法比较顺手,另外,可以拓展为缩略图的控制方法。

Javascript 相关文章推荐
JavaScript中this关键词的使用技巧、工作原理以及注意事项
May 20 Javascript
jquery提示效果实例分析
Nov 25 Javascript
Atitit.js的键盘按键事件捆绑and事件调度
Apr 01 Javascript
微信小程序 页面跳转传值实现代码
Jul 27 Javascript
浅谈react性能优化的方法
Sep 05 Javascript
vue中使用heatmapjs的示例代码(结合百度地图)
Sep 05 Javascript
node.js监听文件变化的实现方法
Apr 17 Javascript
JavaScript回调函数callback用法解析
Jan 14 Javascript
在vue中使用Base64转码的案例
Aug 07 Javascript
Vue和React有哪些区别
Sep 12 Javascript
antd 表格列宽自适应方法以及错误处理操作
Oct 27 Javascript
ReactRouter的实现方法
Jan 25 Javascript
js动态改变select选择变更option的index值示例
Jul 10 #Javascript
javascript event在FF和IE的兼容传参心得(绝对好用)
Jul 10 #Javascript
js确认删除对话框适用于a标签及submit
Jul 10 #Javascript
JQuery1.8 判断元素是否绑定事件的方法
Jul 10 #Javascript
jquery实现类似EasyUI的页面布局可改变左右的宽度
Sep 12 #Javascript
借助JavaScript脚本判断浏览器Flash Player信息的方法
Jul 09 #Javascript
jQuery获取选中内容及设置元素属性的方法
Jul 09 #Javascript
You might like
PHP和Mysqlweb应用开发核心技术-第1部分 Php基础-2 php语言介绍
2011/07/03 PHP
分享一个PHP数据流应用的简单例子
2012/06/01 PHP
PHP贪婪算法解决0-1背包问题实例分析
2015/03/23 PHP
PHP7新增运算符用法实例分析
2016/09/26 PHP
php+jQuery递归调用POST循环请求示例
2016/10/14 PHP
Laravel框架路由管理简单示例
2019/05/07 PHP
js时间戳格式化成日期格式的多种方法
2013/11/11 Javascript
15个jquery常用方法、小技巧分享
2015/01/13 Javascript
JavaScript的History API使搜索引擎抓取AJAX内容
2015/12/07 Javascript
AngularJS实现元素显示和隐藏的几个案例
2015/12/09 Javascript
理解Javascript的call、apply
2015/12/16 Javascript
javascript仿百度输入框提示自动下拉补全
2016/01/07 Javascript
AngularJS中的Directive自定义一个表格
2016/01/25 Javascript
实例详解jQuery的无new构建
2016/08/02 Javascript
nodejs利用http模块实现银行卡所属银行查询和骚扰电话验证示例
2016/12/30 NodeJs
NodeJS实现同步的方法
2019/03/02 NodeJs
Vue开发之封装上传文件组件与用法示例
2019/04/25 Javascript
微信小程序中为什么使用var that=this
2019/08/27 Javascript
微信小程序canvas分享海报功能
2019/10/31 Javascript
JavaScript冒泡算法原理与实现方法深入理解
2020/06/04 Javascript
vue setInterval 定时器失效的解决方式
2020/07/30 Javascript
JS实现纸牌发牌动画
2021/01/19 Javascript
详解vue之自行实现派发与广播(dispatch与broadcast)
2021/01/19 Vue.js
Python中使用MELIAE分析程序内存占用实例
2015/02/18 Python
Python函数装饰器实现方法详解
2018/12/22 Python
python 多进程共享全局变量之Manager()详解
2019/08/15 Python
Python3 socket即时通讯脚本实现代码实例(threading多线程)
2020/06/01 Python
Blue Nile蓝色尼罗河香港官网:世界最大在线钻石珠宝销售商
2020/05/07 全球购物
高三地理教学反思
2014/01/11 职场文书
老公爱的承诺书
2014/03/31 职场文书
教师考核评语
2014/04/28 职场文书
经贸日语专业个人求职信范文
2014/04/29 职场文书
给学校建议书范文
2014/05/13 职场文书
前台岗位职责
2015/02/13 职场文书
2015年团支部工作总结
2015/04/03 职场文书
同学聚会感言一句话
2015/07/30 职场文书