基于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 相关文章推荐
线路分流自动智能跳转代码,自动选择最快镜像网站(js)
Oct 31 Javascript
关于JavaScript中原型继承中的一点思考
Jul 25 Javascript
浅谈JavaScript的事件
Feb 27 Javascript
javascript中不易分清的slice,splice和split三个函数
Mar 29 Javascript
js老生常谈之this,constructor ,prototype全面解析
Apr 05 Javascript
jQuery实现radio第一次点击选中第二次点击取消功能
May 15 jQuery
用Vue.extend构建消息提示组件的方法实例
Aug 08 Javascript
原生js 封装get ,post, delete 请求的实例
Aug 11 Javascript
JavaScript实现简单评论功能
Aug 17 Javascript
详解Vue2.0配置mint-ui踩过的那些坑
Apr 23 Javascript
ES6模板字符串和标签模板的应用实例分析
Jun 25 Javascript
node.js中fs文件系统模块的使用方法实例详解
Feb 13 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/10/09 PHP
PHP 反向排序和随机排序代码
2010/06/30 PHP
PHP中检查isset()和!empty()函数的必要性
2019/02/13 PHP
laravel 数据迁移与 Eloquent ORM的实现方法
2019/04/12 PHP
Smarty模板语法详解
2019/07/20 PHP
tp5.1 框架数据库-数据集操作实例分析
2020/05/26 PHP
JavaScript实现Sleep函数的代码
2007/03/04 Javascript
不要在cookie中使用特殊字符的原因分析
2010/07/13 Javascript
40个有创意的jQuery图片、内容滑动及弹出插件收藏集之一
2011/12/31 Javascript
IE6背景图片不缓存问题解决方案及图片使用策略多个方法小结
2012/05/14 Javascript
JavaScript数组随机排列实现随机洗牌功能
2015/03/19 Javascript
jQuery使用empty()方法删除元素及其所有子元素的方法
2015/03/26 Javascript
vue移动端监听滚动条高度的实现方法
2018/09/03 Javascript
JS 遍历 json 和 JQuery 遍历json操作完整示例
2019/11/11 jQuery
一则python3的简单爬虫代码
2014/05/26 Python
测试、预发布后用python检测网页是否有日常链接
2014/06/03 Python
为Python的web框架编写MVC配置来使其运行的教程
2015/04/30 Python
Python的Django框架可适配的各种数据库介绍
2015/07/15 Python
python爬虫入门教程--利用requests构建知乎API(三)
2017/05/25 Python
python+pyqt实现12306图片验证效果
2017/10/25 Python
Django MEDIA的配置及用法详解
2019/07/25 Python
Python队列RabbitMQ 使用方法实例记录
2019/08/05 Python
Numpy的简单用法小结
2019/08/28 Python
python 实现turtle画图并导出图片格式的文件
2019/12/07 Python
python opencv根据颜色进行目标检测的方法示例
2020/01/15 Python
Django的CVB实例详解
2020/02/10 Python
基于Python获取docx/doc文件内容代码解析
2020/02/17 Python
浅谈keras中自定义二分类任务评价指标metrics的方法以及代码
2020/06/11 Python
Grid 宫格常用布局的实现
2020/01/10 HTML / CSS
NBA德国官方网上商店:NBA Store德国
2018/04/13 全球购物
如何在C# winform中异步调用web services
2015/09/21 面试题
软件设计的目标是什么
2016/12/04 面试题
如何用Java判断一个文件或目录是否存在
2012/11/19 面试题
小学数学教学经验交流材料
2014/05/22 职场文书
2016国培学习心得体会
2016/01/08 职场文书
【DOTA2】半决赛强强对话~ PSG LGD vs EHOME - DPC 2022 CN REGIONAL FINALS WINTER
2022/04/02 DOTA