Chinaunix首页 | 论坛 | 博客
  • 博客访问: 490435
  • 博文数量: 226
  • 博客积分: 0
  • 博客等级: 民兵
  • 技术积分: 2111
  • 用 户 组: 普通用户
  • 注册时间: 2014-06-20 09:02
个人简介

web web web

文章分类

全部博文(226)

文章存档

2020年(2)

2019年(1)

2018年(3)

2017年(26)

2016年(57)

2015年(60)

2014年(77)

我的朋友

分类: JavaScript

2016-01-18 13:39:35

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

  1. $(document).ready(function() {
  2.      $('.post img').each(function() {
  3.      var maxWidth = 100; // 图片最大宽度
  4.      var maxHeight = 100; // 图片最大高度
  5.      var ratio = 0; // 缩放比例
  6.      var width = $(this).width(); // 图片实际宽度
  7.      var height = $(this).height(); // 图片实际高度
  8.    
  9.      // 检查图片是否超宽
  10.      if(width > maxWidth){
  11.          ratio = maxWidth / width; // 计算缩放比例
  12.          $(this).css("width", maxWidth); // 设定实际显示宽度
  13.          height = height * ratio; // 计算等比例缩放后的高度
  14.          $(this).css("height", height); // 设定等比例缩放后的高度
  15.      }
  16.    
  17.      // 检查图片是否超高
  18.      if(height > maxHeight){
  19.          ratio = maxHeight / height; // 计算缩放比例
  20.          $(this).css("height", maxHeight); // 设定实际显示高度
  21.          width = width * ratio; // 计算等比例缩放后的高度
  22.          $(this).css("width", width * ratio); // 设定等比例缩放后的高度
  23.      }
  24.  });
  25.  });
    在不同的浏览器测试效果时,发现此种写法不能适应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函数里
  1. var img= new Image();
  2.     img.src = url;
  3.     img.onload = function(){
  4.     // 需要执行的程序
  5.          动态改变图片实现尺寸并发送ajax请求在室内图上显示对应的ap位置坐标
  6.     }
    结果图片就是动态改变尺寸后显示出来的
阅读(2160) | 评论(0) | 转发(0) |
给主人留下些什么吧!~~