php网页图片中间代码,HTML中三种方法实现img标签只显示图片中心位置的示例代码...

html中 img标签显示图片中心的方法目前知道三种,下面小编把他分享到脚本之家平台,需要的朋友参考下

html中 img标签显示图片中心的方法目前知道三种,在此记录一下

第一种:用到css的clip:rect(top right bottom left);用法,需要配合position: absolute使用:如下

3e3711eb7eeedb20c26c7bd627b612fd.jpg

style="position: absolute;clip: rect(0px,250px,200px,50px);width: 300px;height: 200px">

设置图片的width和height相当于图片实际宽高的等比例缩放,再用rect方法来设置图片的剪切范围。

- 第二种:用img的background属性:

img {

background-image: url(http://img2.utuku.china.com/640x0/news/20170210/77b8b5ca-11d3-4307-9a93-c12df5eb1a35.jpg);//设置背景图片

background-repeat: no-repeat;//背景图像将仅显示一次。

background-attachment: scroll;//

background-position: -50px 0px;//设置背景图片的的偏移量,这个-50相当于背景整体向左偏移50,就可以显示图片的中心

background-size: 300px 200px;设置背景图片的大小,相当于图片实际宽高等比例饿缩放的

background-color: transparent;//

width: 200px;//

height: 200px;//

}

用背景来控制图片显示中心位置,需要设置背景按照图片的真实宽高等比缩放,然后偏移背景的移动量来控制图片的宽高,这个需要注意的是不能图片的src,img标签不设置src时候,显示的图片会出现一条灰色的边框,而且没有办法去掉,border:0px也没有作用,我之前的解决办法是放一张默认的全透明的图片在src中,就可以解决了。

第三种:在p中包含img,用p的overflow: hidden;来控制,用起来比较灵活,

3e3711eb7eeedb20c26c7bd627b612fd.jpg

var img = document.getElementById("img_id");

var image = new Image();

var realWidth = 0;//储存图片实际宽度

var realHeight = 0;//储存图片实际高度

//获取图片的宽高

image.src = "http://img2.utuku.china.com/640x0/news/20170210/77b8b5ca-11d3-4307-9a93-c12df5eb1a35.jpg";

//加载成功的处理

image.onload = function () {

realWidth = image.width;//获取图片实际宽度

realHeight = image.height;//获取图片实际高度

//让img的宽高相当于图片实际宽高的等比缩放,然后再偏移

if (realWidth > realHeight){

img.width = (100/realHeight)*realWidth;//等比缩放宽度

img.height = 100;//跟p高度一致

img.style.left = '-' + ((100/realHeight)*realWidth-100)/2 + 'px';//设置图片相对自己位置偏移为img标签的宽度-高度的一半

}else if (realWidth < realHeight){

img.width =100 ;//跟p高度一致

img.height = (100/realWidth)*realHeight;//等比缩放高度

img.style.top = '-' + ((100/realWidth)*realHeight-100)/2 + 'px';//设置图片相对自己位置偏移为img标签的高度-宽度的一半

}else {

img.width =100 ;

img.height = 100;

}

};

//图片加载失败的处理

img.onerror = function () {

img.src = "https://timgsa.baidu.com/timg?image&quality=80&size=b9999_10000&sec=1492076382452&di=04ebd6c4688b2ffbd8ae18e685234704&imgtype=0&src=http%3A%2F%2Fd.hiphotos.baidu.com%2Fzhidao%2Fwh%253D450%252C600%2Fsign%3D0c96dc86da33c895a62b907fe4235fc6%2F0823dd54564e9258d2bb2dff9f82d158ccbf4e17.jpg";

img.width =100 ;

img.height = 100;

}

上面注释已经很清楚了,主要是p控制了大小,img标签根据p的大小来调节自身的大小。在进行偏移,从而达到显示图片中间部分的图片。个人觉得第三种方法比较好用。

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值