最新文章专题视频专题问答1问答10问答100问答1000问答2000关键字专题1关键字专题50关键字专题500关键字专题1500TAG最新视频文章推荐1 推荐3 推荐5 推荐7 推荐9 推荐11 推荐13 推荐15 推荐17 推荐19 推荐21 推荐23 推荐25 推荐27 推荐29 推荐31 推荐33 推荐35 推荐37视频文章20视频文章30视频文章40视频文章50视频文章60 视频文章70视频文章80视频文章90视频文章100视频文章120视频文章140 视频2关键字专题关键字专题tag2tag3文章专题文章专题2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章专题3
当前位置: 首页 - 科技 - 知识百科 - 正文

JavaScript如何动态改变图片显示大小的示例代码

来源:动视网 责编:小采 时间:2020-11-27 20:15:06
文档

JavaScript如何动态改变图片显示大小的示例代码

JavaScript如何动态改变图片显示大小的示例代码:当我们要显示后台传过来若干个尺寸不一的图片时,为了保证图片大小的一致性及比例的协调,需要动态改变图片显示尺寸。通过搜索,我们可以从网上找到实现此功能的jQuery代码如下。这段代码可以使图片的大小保持在一定范围内,如果图片的原始尺寸都大于max*
推荐度:
导读JavaScript如何动态改变图片显示大小的示例代码:当我们要显示后台传过来若干个尺寸不一的图片时,为了保证图片大小的一致性及比例的协调,需要动态改变图片显示尺寸。通过搜索,我们可以从网上找到实现此功能的jQuery代码如下。这段代码可以使图片的大小保持在一定范围内,如果图片的原始尺寸都大于max*


当我们要显示后台传过来若干个尺寸不一的图片时,为了保证图片大小的一致性及比例的协调,需要动态改变图片显示尺寸。通过搜索,我们可以从网上找到实现此功能的jQuery代码如下。这段代码可以使图片的大小保持在一定范围内,如果图片的原始尺寸都大于max*值,则显示出来的图片宽度都相等。

$(document).ready(function() {
 $('.post img').each(function() {
 var maxWidth = 100; // 图片最大宽度
 var maxHeight = 100; // 图片最大高度
 var ratio = 0; // 缩放比例
 var width = $(this).width(); // 图片实际宽度
 var height = $(this).height(); // 图片实际高度
 
 // 检查图片是否超宽
 if(width > maxWidth){
 ratio = maxWidth / width; // 计算缩放比例
 $(this).css("width", maxWidth); // 设定实际显示宽度
 height = height * ratio; // 计算等比例缩放后的高度 
 $(this).css("height", height); // 设定等比例缩放后的高度
 }
 
 // 检查图片是否超高
 if(height > maxHeight){
 ratio = maxHeight / height; // 计算缩放比例
 $(this).css("height", maxHeight); // 设定实际显示高度
 width = width * ratio; // 计算等比例缩放后的高度
 $(this).css("width", width * ratio); // 设定等比例缩放后的高度
 }
 });
 });

在不同的浏览器测试效果时,发现此种写法不能适应chrome浏览器,会产生图片以原有尺寸显示出来的bug。原来document ready事件是在HTML文档载入即DOM准备好就开始执行了,即使图片资源还没有加载进来。网上有一种说法是用$(window).load()方法包装起来,就能解决chrome浏览器显示不正确的问题-----window load事件执行的稍晚一些,它是在整个页面包括frames, objects和images都加载完成后才开始执行的。从这种区别可以分析出chrome浏览器在对于图片不采用$(window).load()方法处理时,图片载入与动态改变图片的js代码执行顺序不确定。

最近在做的室内图模块,需要先从后台加载室内图图片显示到页面上,为了保证图片大小的一致性及比例的协调,需要动态改变图片显示尺寸,然后在调整大小的室内图上显示对应的ap位置。这里分三步:
1.发送ajax请求,拿到需要加载的室内图的url,更新dom,显示室内图
2.动态改变图片显示尺寸
3.在室内图上显示对应的ap位置坐标
开始我是这样做的:
发送ajax请求,在返回success函数里动态改变图片显示尺寸并发送ajax请求在室内图上显示对应的ap位置坐标,最后的结果是图片是以原有尺寸显示出来的,我调整后的方法是:
发送ajax请求,在返回success函数里

var img= new Image();
 img.src = url;
 img.onload = function(){
 // 需要执行的程序
 动态改变图片实现尺寸并发送ajax请求在室内图上显示对应的ap位置坐标
 }

结果图片就是动态改变尺寸后显示出来的

文档

JavaScript如何动态改变图片显示大小的示例代码

JavaScript如何动态改变图片显示大小的示例代码:当我们要显示后台传过来若干个尺寸不一的图片时,为了保证图片大小的一致性及比例的协调,需要动态改变图片显示尺寸。通过搜索,我们可以从网上找到实现此功能的jQuery代码如下。这段代码可以使图片的大小保持在一定范围内,如果图片的原始尺寸都大于max*
推荐度:
标签: 图片 如何 动态
  • 热门焦点

最新推荐

猜你喜欢

热门推荐

专题
Top