clip-path属性可实现元素的非矩形裁剪,支持inset、circle、ellipse和polygon等函数,适用于创建三角形图片、六边形按钮等复杂形状,并可通过transition实现悬停动画,配合百分比单位适配响应式设计,现代浏览器广泛支持但Safari需加-webkit-前缀,旧浏览器应提供视觉降级方案。

使用 CSS 的 clip-path 属性可以轻松实现元素的裁剪效果,只显示指定区域,其余部分被隐藏。它比传统的 overflow: hidden 更灵活,支持圆形、多边形、椭圆等复杂形状。
基础语法与常用形状
clip-path 支持多种内置函数,可以直接定义裁剪区域:
- clip-path: inset(20%) —— 内凹裁剪,类似 margin,可设置上右下左
- clip-path: circle(50px at center) —— 以中心为原点,裁剪出半径 50px 的圆形
- clip-path: ellipse(60px 40px at 50% 50%) —— 椭圆裁剪,x/y 半径和位置
- clip-path: polygon(0 0, 100% 0, 50% 100%) —— 多边形,用多个坐标点定义形状
例如,将一张图片裁剪成三角形:
img {clip-path: polygon(50% 0%, 0% 100%, 100% 100%);
}
使用百分比或具体坐标控制形状
多边形中的坐标可以用像素、百分比或混合单位。百分比相对于元素自身宽高计算,更适合响应式设计。
立即学习“前端免费学习笔记(深入)”;
比如创建一个六边形按钮:
.hexagon {width: 200px;
height: 100px;
background: #3498db;
clip-path: polygon(
25% 0%, 75% 0%,
100% 50%, 75% 100%,
25% 100%, 0% 50%
);
}
结合动画与交互增强视觉效果
clip-path 可用于制作过渡或悬停动画。比如鼠标移入时展开内容:
.box {clip-path: inset(50%);
transition: clip-path 0.4s ease;
}
.box:hover {
clip-path: inset(0);
}
注意:只有部分 clip-path 形状在主流浏览器中支持动画(如 inset 和 polygon)。
兼容性与降级处理
现代浏览器基本支持 clip-path,但 Safari 可能需要 -webkit- 前缀。对于不支持的旧浏览器,建议提供视觉降级方案,比如用背景图或简单边框代替。
-webkit-clip-path: polygon(0 0, 100% 0, 50% 100%);
clip-path: polygon(0 0, 100% 0, 50% 100%);
}
基本上就这些。掌握 clip-path 能让你摆脱矩形布局限制,创造出更生动的界面效果,不复杂但容易忽略细节位置控制。










