html怎么设置扩大缩小不变形,DiV里CSS控制图片按比例扩大缩小不变形

一般来说,我们设定一定宽度高度的div标签,在里面放上图片,只有当图片大小尺寸符合这个宽度和高度的时候显示最佳。那有的时候不同的界面,同样的信息(比如头像)放大的尺寸是不一样,怎么才能让图片根据DIV的宽高度进行,缩放呢?其实很简单,只用设置其css样式即可,css样式如下:

.photo img

{

max-width:80px;/*这是DIV的大小*/

width:expression(this.width > 80 ? "80px" : this.width);/*实现按比例缩放*/

}

HTML中设置如下:

368595fe6496265186af4d93a5fb445a.png

下面是完整的代码,读者可以在IE5以上的浏览器中运行:

Div里CSS控制图片按比例扩大缩小不变形

.photo img

{

max-width:120px; /*这是DIV的大小*/

width:expression(this.width > 120 ? "120px" : this.width);/*实现按比例缩放*/

}

368595fe6496265186af4d93a5fb445a.png
368595fe6496265186af4d93a5fb445a.png

注意:除了IE之外,其他浏览器比如Chrome、Firefox、Safari对expression这种非标准的用法并不支持。

expression是在IE5版本之后支持使用的,用来把CSS属性和Javascript脚本关联起来,【这里的CSS属性可以是元素固有的属性,也可以是自定义属性。】是动态设置CSS属性的强大方法,但也存在着一定的危险性。

CSS属性后面可以是一段Javascript表达式,CSS属性的值等于Javascript表达式计算的结果。

注意:

不是非常需要,一般不建议使用expression,因为expression对浏览器资源要求比较高。

CSS Expression的问题就在于它的计算频率要比想象的多出很多。不仅仅是在页面显示和缩放时,就是在页面滚动、乃至移动鼠标时都会要重新计算一次。CSS expression作为web时代临时解决方案的产物,在被其创建者无情的抛弃后,我们更应该摈弃这种较为丑陋的代码方式,采用更优的解放方案。

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值