基于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为对象原型prototype添加属性的两种方式
Aug 01 Javascript
javascript获取checkbox复选框获取选中的选项
Aug 12 Javascript
修改或扩展jQuery原生方法的代码实例
Jan 13 Javascript
IE10中flexigrid无法显示数据的解决方法
Jul 26 Javascript
深入理解JQuery中的事件与动画
May 18 Javascript
jQuery实现标签页效果实战(4)
Feb 08 Javascript
HTML的select控件美化
Mar 27 Javascript
JS实现仿饿了么在浏览器标签页失去焦点时网页Title改变
Jun 01 Javascript
在React 组件中使用Echarts的示例代码
Nov 08 Javascript
基于Vue的移动端图片裁剪组件功能
Nov 28 Javascript
基于vue2.0实现仿百度前端分页效果附实现代码
Oct 30 Javascript
微信小程序canvas分享海报功能
Oct 31 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 中的输出缓冲
2006/12/21 PHP
PHP循环结构实例讲解
2014/02/10 PHP
PHP制作3D扇形统计图以及对图片进行缩放操作实例
2014/10/23 PHP
PHP多线程之内部多线程实例分析
2015/03/09 PHP
laravel批量生成假数据的方法
2019/10/09 PHP
Jquery css函数用法(判断标签是否拥有某属性)
2011/05/28 Javascript
jquery自动将form表单封装成json的具体实现
2014/03/17 Javascript
使用Nodejs开发微信公众号后台服务实例
2014/09/03 NodeJs
使用JSON.parse将json字符串转换成json对象的时候会出错
2014/09/04 Javascript
jQuery $命名冲突解决方案汇总
2014/11/13 Javascript
Ionic 2 实现列表滑动删除按钮的方法
2017/01/22 Javascript
bootstrap实现动态进度条效果
2017/03/08 Javascript
Vuex中mutations与actions的区别详解
2018/03/01 Javascript
浅谈Node 调试工具入门教程
2018/03/20 Javascript
详解.vue文件中style标签的几个标识符
2018/07/17 Javascript
vue elementUI table表格数据 滚动懒加载的实现方法
2019/04/04 Javascript
小程序如何获取多个formId实现详解
2019/09/20 Javascript
JavaScript 监听组合按键思路及代码实现
2020/07/28 Javascript
python改变日志(logging)存放位置的示例
2014/03/27 Python
Python生成随机MAC地址
2015/03/10 Python
详解Python中的Descriptor描述符类
2016/06/14 Python
Windows下安装Django框架的方法简明教程
2018/03/28 Python
Python PyQt4实现QQ抽屉效果
2018/04/20 Python
python GUI库图形界面开发之PyQt5打印控件QPrinter详细使用方法与实例
2020/02/28 Python
Django中的DateTimeField和DateField实现
2021/02/24 Python
Pamela Love官网:纽约设计师Pamela Love的精美、时尚和穿孔珠宝
2020/10/19 全球购物
几道数据库的面试题或笔试题
2014/05/31 面试题
腾讯公司的一个sql题
2013/01/22 面试题
法律进企业活动方案
2014/03/04 职场文书
教学改革实施方案
2014/03/31 职场文书
2014年纠风工作总结
2014/12/08 职场文书
索赔员岗位职责
2015/02/15 职场文书
城南旧事观后感
2015/06/11 职场文书
生产设备维护保养制度
2015/08/06 职场文书
诗词赏析-(浣溪沙)
2019/08/13 职场文书
JavaScript实现九宫格拖拽效果
2022/06/28 Javascript