基于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下高性能字符串连接StringBuffer类
Aug 16 Javascript
jquery如何判断某元素是否具备指定的样式
Nov 05 Javascript
解析JavaScript中instanceof对于不同的构造器或许都返回true
Dec 03 Javascript
js判断上传文件类型判断FileUpload文件类型代码
May 20 Javascript
js点击列表文字对应该行显示背景颜色的实现代码
Aug 05 Javascript
基于bootstrap插件实现autocomplete自动完成表单
May 07 Javascript
基于jQuery实现简单人工智能聊天室
Feb 10 Javascript
Vue-Router实现组件间跳转的三种方法
Nov 07 Javascript
使用p5.js临摹动态图形
Oct 23 Javascript
Javascript实现贪吃蛇小游戏(含详细注释)
Oct 23 Javascript
vue-router懒加载的3种方式汇总
Feb 28 Vue.js
前端框架ECharts dataset对数据可视化的高级管理
Dec 24 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
url decode problem 解决方法
2011/12/26 PHP
详解PHP错误日志的获取方法
2015/07/20 PHP
thinkphp自带验证码全面解析
2016/09/18 PHP
PHP中使用CURL发送get/post请求上传图片批处理功能
2018/10/15 PHP
php实现每日签到功能
2018/11/29 PHP
jquery预览图片实现鼠标放上去显示实际大小
2014/01/16 Javascript
jquery实现个人中心导航菜单效果和美观都非常不错
2014/09/02 Javascript
jQuery中next()方法用法实例
2015/01/07 Javascript
jQuery实现html表格动态添加新行的方法
2015/05/28 Javascript
浅谈利用JavaScript进行的DDoS攻击原理与防御
2015/06/04 Javascript
AngularJS+Node.js实现在线聊天室
2015/08/28 Javascript
node.js从数据库获取数据
2016/05/08 Javascript
DOM中事件处理概览与原理的全面解析
2016/08/16 Javascript
基于JS实现横线提示输入验证码随验证码输入消失(js验证码的实现)
2016/10/27 Javascript
H5上传本地图片并预览功能
2017/05/08 Javascript
Vue应用部署到服务器的正确方式
2017/07/15 Javascript
Vue进度条progressbar组件功能
2018/04/17 Javascript
JS实现动态星空背景效果
2019/11/01 Javascript
vue中使用elementUI组件手动上传图片功能
2019/12/13 Javascript
Python计时相关操作详解【time,datetime】
2017/05/26 Python
python单向链表的基本实现与使用方法【定义、遍历、添加、删除、查找等】
2019/10/24 Python
python多进程重复加载的解决方式
2019/12/13 Python
HTML5和CSS3实例教程总结(推荐)
2016/07/18 HTML / CSS
iHerb香港:维生素、补充剂和天然保健品
2017/08/01 全球购物
英国最大的运动营养公司之一:LA Muscle
2018/07/02 全球购物
精致的手工皮鞋:Shoe Embassy
2019/11/08 全球购物
初中军训感想300字
2014/03/05 职场文书
学历公证书范本
2014/04/09 职场文书
大学班级学风建设方案
2014/05/01 职场文书
大学生见习报告总结
2014/11/04 职场文书
2014年实习班主任工作总结
2014/11/08 职场文书
工作表扬信范文
2015/01/17 职场文书
关于应聘教师的自荐信
2016/01/28 职场文书
2016大学先进团支部事迹材料
2016/03/01 职场文书
2019个人工作计划书的格式及范文!
2019/07/04 职场文书
使用CSS实现一个搜索引擎的原理解析
2021/09/25 HTML / CSS