在 CSS 世界里,边框不只是 border
一条路。你可能一直用 border
写边框,hover 时元素宽度变化、渐变边框做不出来......其实,现在有更酷、更灵活的方式来实现边框效果。今天我们就来盘一盘------都有哪些边框"新玩法",以及什么时候用它们最合适。
1️⃣ 传统 border
html
.element {
border: 2px solid #0d98ff;
border-radius: 12px;
}
优点:
- 简单直接,兼容性最好
- 可控边宽、样式、颜色
缺点:
- 不支持渐变、阴影等复杂效果
- hover 动态变化会影响元素大小(因为 border 会占空间)
✅ 适用场景: 简单实用,没特别设计需求时首选。
2️⃣ 伪元素 + 背景/渐变
html
.element {
position: relative;
border-radius: 12px;
}
.element::before {
content: '';
position: absolute;
inset: 0;
padding: 2px;
border-radius: inherit;
background: linear-gradient(90deg, #0d98ff, #0b56a2);
-webkit-mask: linear-gradient(#fff 0 0) content-box, linear-gradient(#fff 0 0);
-webkit-mask-composite: xor;
mask-composite: exclude;
pointer-events: none;
transition: background 0.2s ease-in-out;
}
优点:
- 支持渐变、动画、虚化等高级效果
- 不影响元素内容和布局
缺点:
- 代码稍复杂
- 兼容性需要注意
-webkit-mask
和mask-composite
✅ 适用场景: 想要炫酷渐变边框、hover 动画,完美解决传统 border 的局限。
💡 小技巧:用伪元素控制边框,hover 只改变伪元素背景,不会让元素宽度跳动。
3️⃣ outline
html
.element {
outline: 2px solid #0d98ff;
}
优点:
- 不占用元素空间
- 用于 focus、hover 提示很方便
缺点:
- 只能是单色,无法圆角或渐变
- 样式比较简单
✅ 适用场景: 边框高亮、可访问性提示(例如表单聚焦时的高亮效果)。
4️⃣ box-shadow
html
.element {
box-shadow: 0 0 0 2px #0d98ff;
border-radius: 12px;
}
优点:
- 不占用空间,可以叠加多层
- 可以配合透明度或伪元素实现渐变边框效果
缺点:
- 单独
box-shadow
不能直接使用渐变 - 调整厚度或位置需要调
spread
✅ 适用场景: 想要内外发光、渐变或阴影边框效果。
🔹 总结推荐
需求类型 | 推荐方式 |
---|---|
简单实用 | border |
炫酷渐变/hover 动画 | 伪元素 + gradient /mask |
临时高亮或 focus 提示 | outline |
内外发光 / 柔和边框效果 | box-shadow |
🔑 小结
border
太单调?用伪元素 + 渐变来实现炫酷边框。- hover 想要平滑过渡?用伪元素控制边框,而不是改变
border
宽度。 - 想让元素更灵动、更有层次?
box-shadow
+ 透明度组合,让边框效果丰富。
都5202年了,是时候让你的边框也跟上潮流了。💥
参考链接: juejin.cn/post/753800...