假设我想要一种方法来显示HTML中250x250px图像的中心50x50px.我怎样才能做到这一点.另外,有没有办法为css:url()引用执行此操作?
我知道CSS中的剪辑,但这似乎只适用于绝对定位.
虽然你已经接受了答案,但我只是补充说有(有点鲜为人知的)clip
css属性,虽然它确实要求被剪裁的元素是position: absolute;
(这是一种耻辱):
.container {
position: relative;
}
#clip {
position: absolute;
clip: rect(0, 100px, 200px, 0);
/* clip: shape(top, right, bottom, left); NB 'rect' is the only available option */
}
一种方法是将要显示的图像设置为容器中的背景(td,div,span等),然后调整背景位置以获得所需的精灵.
另一种选择是以下,虽然不是最干净的,因为它假定图像是容器中的唯一元素,例如在这种情况下:
然后,您可以将容器用作具有所需大小的蒙版,并使用负边距围绕图像以将其移动到正确的位置:
.siteHeader{
width: 50px;
height: 50px;
overflow: hidden;
}
.siteHeader .siteLogo{
margin: -100px;
}
演示可以在这个JSFiddle中看到.
似乎只能在IE> 9中工作,并且可能是所有其他浏览器的所有重要版本.