html中图片只显示部分,两种方法实现css切割图片,只取图片中一部分

本文介绍了如何通过CSS将多个小图标合并到一张图片中,以减少HTTP请求,提高网页加载速度。主要讨论了两种方法:一是利用background属性设置背景图片的位置和大小;二是使用img标签的clip属性进行裁剪。在实践中,注意到background-position可以调整显示的图标位置,而clip属性需要配合position: absolute实现图标截取。操作中遇到的问题包括rect方法内逗号的使用和需要设置绝对定位。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

参考地址:http://www.jb51.net/css/150036.html

场景:如果一个页面有个img小图标,那么访问浏览器的时候会因为加载图片导致浏览速度放慢。这个时候将这么多的小图标放在一起,整合成一个img,那么只需要访问一张图片就可以了。就可以减少请求图片的次数

4e11dea18d53

整合后的img

那么整合后的img有了,在使用的过程中如何获取我们想要的像素范围呢?上面的参考地址有写。我就照着做一遍吧。

方法一

在CSS中元素的background:background-color || background-image || background-repeate || background-attachment || background-position,示例如下:background:transparent url(123.jpg) no-repeat scroll -140px -20px;transparent 表示透明度无颜色

url(123.jpg) 表示背景图片

no-repeat 表示图片不重复

scroll 表示背景图片随浏览器下拉而滚动

-140px 表示水平位置在图片的-140px处(以图片的左上角为0,0)

-20px 表示垂直位置在图片的-20px处

但是我发现上面的不适合我想要的,

4e11dea18d53

上面的效果来看只能显示图片的右下角。那再试试第二种方法

方法二

用 img 的 clip 属性中的 rect ,clip:rect(y1,y2,x2,x1)参数说明如下

y1 = 定位的 y 坐标(垂直方向)的起点

y2 = 定位的 y 坐标(垂直方向)的终点

x1 = 定位的 x 坐标(垂直方向)的起点

x2 = 定位的 x 坐标(垂直方向)的终点

注意:坐标的起点是在左上角

代码如下:img{

position:absolute;

clip:rect(20px ,100px , 50px , 20px);

}

4e11dea18d53

在实际操作过程中,发现两个问题:1.rect方法里面需要带上逗号,2.必须要带上position,并且需要是绝对定位,也就是absolute 或者 fixed属性。

就这样

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值