首页 > 编程 > JS > 正文

js+css图片自动等比例缩小且垂直居中

2020-09-19 11:11:49
字体:
来源:转载
供稿:网友

原文连接:http://www.ddcat.net/blog/archives/2007/10/188.html

  图片自动等比例缩小,其实如果不考虑ie6的话,用css就可以实现,设定img的max-width和max-height,而<img>标签内不设定widht和height即可。 

  ie7已经支持max-width和max-height,这是为数不多的好消息之一。 但是对于ie6及以前的版本,就只能用js来设置了。 

  在 ff 2.0/ ie6 / ie7 中测试通过。 opera 8.5 cn 垂直居中未通过,正在研究[貌似opera下如果只有图片行高会失效……]。希望大家来测试。

<!doctype html public "-//w3c//dtd xhtml 1.0 transitional//en" "http://www.w3.org/tr/xhtml1/dtd/xhtml1-transitional.dtd"> 
<html xmlns="http://www.w3.org/1999/xhtml"> 
<head> 
<meta http-equiv="content-type" content="text/html; charset=gb2312" /> 
<title>图片自动等比例缩小且垂直居中</title> 
<!--[if lte ie 6]> 
<script type="text/javascript" language="javascript"> 
function imgfix() { 
  //定义要限制的图片宽高,这个宽高要同style里面定义的相同,小于限定高宽的图片不操作 
  var widthrestriction = 200; 
  var heightrestriction = 200; 
  var allelements = document.getelementsbytagname('*')   
  for (var i = 0; i < allelements.length; i++) 
  { 
    if (allelements[i].classname.indexof('imgbox') >= 0) 
        { 
      var imgelements = allelements[i].getelementsbytagname('img'); 
      for (var j=0; j < imgelements.length; j++) 
          { 
        if ( imgelements[j].width > widthrestriction || imgelements[j].height > heightrestriction ) 
                { 
          if ( imgelements[j].width > imgelements[j].height) 
                  { 
            imgelements[j].height = imgelements[j].height*(widthrestriction/imgelements[j].width); 
            imgelements[j].width = widthrestriction; 
          } else 
                  { 
            imgelements[j].width = imgelements[j].width*(heightrestriction/imgelements[j].height); 
            imgelements[j].height = heightrestriction; 
          } 
        } 
                if ( imgelements[j].height < heightrestriction ) 
                { 
                  imgelements[j].style.paddingtop = ( heightrestriction -imgelements[j].height ) /2 + "px"; 
                } 
      } /*for j*/ 
    } 
  }/*for i*/ 

window.onload = imgfix; 
</script> 
<![endif]--> 
<style type="text/css"> 
<!-- 
* { 
margin:0; 
padding:0; 

.imgbox li { 
list-style:none; 
width:200px;  /* 宽度 */ 
height:200px; /* 高度 */ 
background:#ccc; 
border:1px solid #666; 
text-align:center; 
margin:5px; 
line-height:200px; 

.imgbox img { 
max-width:200px;  /* 宽度 */ 
max-height:200px; /* 高度 */ 
vertical-align:middle; 

--> 
</style> 
</head> 

<body> 
<ul class="imgbox"> 
  <li><img src="......" alt="img" /></li> 
  <li><img src="......" alt="img" /></li> 
  <li><img src="......" alt="img" /></li> 
  <li><img src="......" alt="img" /></li> 
</ul> 
</body> 
</html>
发表评论 共有条评论
用户名: 密码:
验证码: 匿名发表