纯CSS无表达式实现未知尺寸图片等比缩放(支持IE7及以上)

栏目:建站技术 2020-10-30

在制作网页的时候,常常会遇到一种情况,我们需要把一些未知尺寸的图片放在一个固定宽高的容器中,这时候我们需要考虑这样的问题:

只给图片设置宽度或高度的其中一项可以实现图片等比缩放,但图片可能超出容器大小。
给图片设置固定的宽高可能导致图片变形。

有些人可能会简单地用JavaScript解决:


代码如下:

<img src="image-url.png" onload="if(this.width > 100){this.width =  100;}if(this.height > 100){this.height = 100;}" />

但在这种写法在图片长宽差距较大时还是会出现图片变形的情况,优化了缩放算法的代码如下:


代码如下:

<!doctype html>
<html>
<head>
<meta charset="UTF-8">
<title>JavaScript实现图片等比缩放</title>
</head>
<body>
<script type="text/javascript">
function resize(element, maxWidth, maxHeight){
if(element.width > maxWidth || element.height > maxHeight){
if(element.width / element.height > maxWidth / maxHeight){
element.width = maxWidth;
}else{
element.height = maxHeight;
}
}
}
</script>
<img src="image-url.png" onload="resize(this, 100, 100);" />
</body>
</html>

而在不考虑IE6的情况下,可以直接使用CSS来实现,而且不需要使用低性能的CSS表达式:


代码如下:

<!doctype html>
<html>
<head>
<meta charset="UTF-8">
<title>纯CSS无表达式实现图片等比缩放</title>
<style>
.box{
width: 300px;
height: 300px;
text-align: center;
border: 1px solid #ccc;
}
.box img{
max-width: 100%;
max-height: 100%;
width: auto;
height: auto;
}
</style>
</head>
<body>
<div><img src="image-url.png" alt=""></div>
</body>
</html>
 

 

示例代码如下
<script type="text/javascript">
function resize(element, maxWidth, maxHeight){
if(element.width > maxWidth || element.height > maxHeight){
if(element.width / element.height > maxWidth / maxHeight){
element.width = maxWidth;
}else{
element.height = maxHeight;
}
}
}
</script>
<style type="text/css">
    border:1px #CCCCCC solid;
    width:130px;
    height:130px;
    text-align:center;
    display:table-cell;
    vertical-align:middle;
</style>
<div>
<a href="#"><img src="图片地址" onload="resize(this, 130, 130);"/></a>
</div>

相关阅读

正则表达式收集汇总

2020-12-1272

搜索:empty(($)tr[&#39;([a-z]{1,})&#39;]),可以查找这样的empty($tr[&#39;digest&#39;]),然后可以替换成!$digest替换:!$1$2匹配A标签的超连接的正则表式如下$pattern=&quot;/&lt;a[^&gt;]+?href=[&quot;&#39;]?([^&quot;&#39;]+)…

帝国CMS-采集关键的经验总结

2020-10-1025

采集关键的几个步骤一:先建好栏目二:增加采集节点(需要选择栏目)三:录入节点名称四:如果有很多页,只需录入采集页面地址方式二中的内容地址为http://www.sznest.net/news.asp?big_class_id=3&amp;page=[page]页码从1到多少页之间、间隔倍数为1(这个多少页即被采集的网站的实际页数,注意这里修改后,在采集页面地…

如何让你的PHP网站变得更安全

2020-10-1064

安全配置一(1)打开php的安全模式php的安全模式是个非常重要的内嵌的安全机制,能够控制一些php中的函数,比如system(),同时把很多文件操作函数进行了权限控制,也不允许对某些关键文件的文件,比如/etc/passwd,但是默认的php.ini是没有打开安全模式的,我们把它打开:safe_mode=on(2)用户组安全当safe_mode打开时,sa…

过滤所有标点符号的函数详解

2020-10-1064

为了避免用户输入的一些特殊标点对数据查询造成干扰,所以对特殊的标点符号的过滤是很有必要,下面是过滤所有标点符号这个函数的详细说明所有的标点符号~|`|!|@|#|$|%|^|&amp;|&#39;|*|(|)|+||||=|-|_|[|]|}|{|;|&quot;|:|?|&gt;|&lt;|,|.|/|��|��|��|��|��|��|}|��|��|�…

360浏览器header的Location跳转无效的解决办法

2020-10-10428

在百度里搜索这个问题的答案,有的说是BOM头导致的问题,有的点是因为之前有输出语句导致的问题,有的话是Location和后面的:(冒号)之间有空格导致的问题,还有的话是因为没有加上exit()导致的问题,但是这几项都排除之外,用360浏览器8.1版本的仍然会有这种情况的发生,那么可以接着继续往下看如果用360浏览器8.1版本的打开“你的域名/admin/te…

如何解决QQ显示未启用的问题

2024-08-8216

没设置临时会话,一般都会出现下面的状况。QQ放在网站上作为客服,必须设置临时会话。或者点击之后,要求加为好友才可以对话。解决这个问题的步骤如下:一、登陆腾讯官方网站:http://wp.qq.com/二、登陆之后,点“设置”,按下图所示,全部打勾。这个必须设置,不设置,不能临时会话,就会显示“未启用”。这一步是关键,必须设置。(1)先看服务有没被停用:如停用…