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

我知道 夹子 在 CSS 中,但这似乎只在与绝对定位一起使用时才有效。

有帮助吗?

解决方案

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

其他提示

虽然您已经接受了答案,但我只是补充一点(有点鲜为人知) 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 */
}
<div class="container">
  <img src="http://lorempixel.com/200/200/nightlife/3" />
</div>
<div class="container">
  <img id="clip" src="http://lorempixel.com/200/200/nightlife/3" />
</div>

JS 小提琴演示, ,用于实验。

为了补充原来的答案——有点晚了——我正在编辑以展示 clip-path, ,它取代了现已弃用的 clip 财产。

clip-path 属性允许一系列选项(比原来的更多) clip), 的:

  • inset — 矩形/长方体形状,用四个值定义为“距离” (top right bottom left).
  • circlecircle(diameter at x-coordinate y-coordinate).
  • ellipseellipse(x-axis-length y-axis-length at x-coordinate y-coordinate).
  • polygon — 由一系列定义 x/y 相对于元素左上角原点的坐标。由于路径自动闭合,多边形的实际最小点数应为 3,少于 2 的为一条线或 1 为一个点: polygon(x-coordinate1 y-coordinate1, x-coordinate2 y-coordinate2, x-coordinate3 y-coordinate3, [etc...]).
  • url — 这可以是本地 URL(使用 CSS id 选择器)或外部文件的 URL(使用文件路径)来标识 SVG,尽管我还没有尝试过其中任何一个(到目前为止),所以我无法提供有关其好处或警告的见解。

div.container {
  display: inline-block;
}
#rectangular {
  -webkit-clip-path: inset(30px 10px 30px 10px);
  clip-path: inset(30px 10px 30px 10px);
}
#circle {
  -webkit-clip-path: circle(75px at 50% 50%);
  clip-path: circle(75px at 50% 50%)
}
#ellipse {
  -webkit-clip-path: ellipse(75px 50px at 50% 50%);
  clip-path: ellipse(75px 50px at 50% 50%);
}
#polygon {
  -webkit-clip-path: polygon(50% 0, 100% 38%, 81% 100%, 19% 100%, 0 38%);
  clip-path: polygon(50% 0, 100% 38%, 81% 100%, 19% 100%, 0 38%);
}
<div class="container">
  <img id="control" src="http://lorempixel.com/150/150/people/1" />
</div>
<div class="container">
  <img id="rectangular" src="http://lorempixel.com/150/150/people/1" />
</div>
<div class="container">
  <img id="circle" src="http://lorempixel.com/150/150/people/1" />
</div>
<div class="container">
  <img id="ellipse" src="http://lorempixel.com/150/150/people/1" />
</div>
<div class="container">
  <img id="polygon" src="http://lorempixel.com/150/150/people/1" />
</div>

JS 小提琴演示, ,用于实验。

参考:

另一种选择如下,尽管不是最干净的,因为它假设图像是容器中的唯一元素,例如在本例中:

<header class="siteHeader">
  <img src="img" class="siteLogo" />
</header>

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

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

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

演示可以在 这个 JSFiddle.

似乎仅适用于 IE>9,并且可能适用于所有其他浏览器的所有重要版本。

许可以下: CC-BY-SA归因
不隶属于 StackOverflow
scroll top