当前位置:  开发笔记 > 编程语言 > 正文

如何在HTML/CSS中仅显示图像的一部分?

如何解决《如何在HTML/CSS中仅显示图像的一部分?》经验,为你挑选了3个好方法。

假设我想要一种方法来显示HTML中250x250px图像的中心50x50px.我怎样才能做到这一点.另外,有没有办法为css:url()引用执行此操作?

我知道CSS中的剪辑,但这似乎只适用于绝对定位.



1> David Thomas..:

虽然你已经接受了答案,但我只是补充说有(有点鲜为人知的)clipcss属性,虽然它确实要求被剪裁的元素是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 */
}


2> Espo..:

一种方法是将要显示的图像设置为容器中的背景(td,div,span等),然后调整背景位置以获得所需的精灵.


@Espo,这似乎是一个相当标准的方法,但是,如果你有一个精灵图像包含几个大小为32x32的单个图像,并且你想在div,span等大于32x32上显示其中1个,那该怎么办? .设置背景位置不再有效.
@ series0ne你可以和[`background-size`]结合使用(https://developer.mozilla.org/en-US/docs/Web/CSS/background-size)

3> Vincent..:

另一种选择是以下,虽然不是最干净的,因为它假定图像是容器中的唯一元素,例如在这种情况下:


然后,您可以将容器用作具有所需大小的蒙版,并使用负边距围绕图像以将其移动到正确的位置:

.siteHeader{
    width: 50px;
    height: 50px;
    overflow: hidden;
}

.siteHeader .siteLogo{
    margin: -100px;
}

演示可以在这个JSFiddle中看到.

似乎只能在IE> 9中工作,并且可能是所有其他浏览器的所有重要版本.

推荐阅读
yzh148448
这个屌丝很懒,什么也没留下!
DevBox开发工具箱 | 专业的在线开发工具网站    京公网安备 11010802040832号  |  京ICP备19059560号-6
Copyright © 1998 - 2020 DevBox.CN. All Rights Reserved devBox.cn 开发工具箱 版权所有