Перейти к содержанию

clip-path

Свойство clip-path создает ограниченную область, которая определяет какая часть элемента должна быть видимой.

Те части, которые находятся внутри области, видимы, в то время как части вне области, скрыты. Обрезанная область — это траектория, определяемая либо как внутренняя ссылка, либо как внешний SVG, либо как фигура, такая как круг (circle()).

Свойство clip-path заменило устаревшее свойство clip.

Демо

Маски и Фигуры

Синтаксис

 1
 2
 3
 4
 5
 6
 7
 8
 9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
/* Keyword values */
clip-path: none;

/* <clip-source> values */
clip-path: url(resources.svg#c1);

/* <geometry-box> values */
clip-path: margin-box;
clip-path: border-box;
clip-path: padding-box;
clip-path: content-box;
clip-path: fill-box;
clip-path: stroke-box;
clip-path: view-box;

/* <basic-shape> values */
clip-path: inset(100px 50px);
clip-path: circle(50px at 0 100px);
clip-path: ellipse(50px 60px at 0 10% 20%);
clip-path: polygon(50% 0%, 100% 50%, 50% 100%, 0% 50%);
clip-path: path(
    'M0.5,1 C0.5,1,0,0.7,0,0.3 A0.25,0.25,1,1,1,0.5,0.3 A0.25,0.25,1,1,1,1,0.3 C1,0.7,0.5,1,0.5,1 Z'
);

/* Box and shape values combined */
clip-path: padding-box circle(50px at 0 100px);

/* Global values */
clip-path: inherit;
clip-path: initial;
clip-path: revert;
clip-path: revert-layer;
clip-path: unset;

Значения

Свойство clip-path определяется как одно или комбинация значений перечисленных ниже.

none

Обрезанная область не создается.

url()

Представляет URL ссылку на траекторию, ограничивающую элемент.

inset(), circle(), ellipse(), polygon()

Функция <basic-shape>. Размер и положение области определяется значением <geometry-box>. Если геометрия не определена, border-box будет использоваться в качестве блока.

<geometry-box>

Если определен в комбинации с <basic-shape>, это значение определяет блок для базовой области. Если задан самостоятельно, определяет границы блока, включая формирование углов (такое как border-radius).

Геометрия может быть определена с помощью одного из следующих значений:

fill-box

Использует границы объекта в качестве базовой области.

stroke-box

Использует stroke bounding box в качестве базовой области.

view-box

Использует ближайший SVG viewport в качестве базового блока. Если отриут viewBox определен для элемента, создающего SVG viewport, базовый блок позиционируется в оригинальной системе координат, установленной атрибутом viewBox и ширина и высота базового блока устанавливаются равными значениям атрибута viewBox.

margin-box

Использует margin box в качестве базового блока.

border-box

Использует border box в качестве базового блока.

padding-box

Использует padding box в качестве базового блока.

content-box

Использует content box в качестве базового блока.

Значение по-умолчанию:

1
clip-path: none;

Применяется ко всем элементам; в SVG, это применяется к контейнерам, исключая элемент defs и все графические элементы

Спецификации

Поддержка браузерами

Can I Use css-clip-path? Data on support for the css-clip-path feature across the major browsers from caniuse.com.

Описание и примеры

 1
 2
 3
 4
 5
 6
 7
 8
 9
10
11
12
13
14
15
16
17
18
19
20
21
22
<img
  id="clipped"
  src="https://mdn.mozillademos.org/files/12668/MDN.svg"
  alt="MDN logo"
/>
<svg height="0" width="0">
  <defs>
    <clipPath id="cross">
      <rect y="110" x="137" width="90" height="90" />
      <rect x="0" y="110" width="90" height="90" />
      <rect x="137" y="0" width="90" height="90" />
      <rect x="0" y="0" width="90" height="90" />
    </clipPath>
  </defs>
</svg>

<select id="clipPath">
  <option value="none">none</option>
  <option value="circle(100px at 110px 100px)">circle</option>
  <option value="url(#cross)" selected>cross</option>
  <option value="inset(20px round 20px)">inset</option>
</select>
1
2
3
4
#clipped {
  margin-bottom: 20px;
  clip-path: url(#cross);
}

Комментарии