CSS边框实现折角效果_结合线性渐变与盒模型

2次阅读

css折角本质是遮罩,用两个伪元素配合linear-gradient斜向渐变模拟,关键在135deg角度、透明与实色段等长、尺寸精准匹配及盒模型留白。

CSS边框实现折角效果_结合线性渐变与盒模型

折角效果本质是遮罩,不是真“切角”

纯CSS做折角(比如右上角撕纸感、标签页斜切),没法靠border-radiusclip-path直接描出锐利斜边——浏览器不支持非直角路径裁剪的像素级控制。真正可靠的做法是用两个叠在一起的::before::after伪元素,一个画底色块,一个用linear-gradient盖出斜线“缺口”,视觉上模拟折角。

linear-gradient画斜边必须注意角度和尺寸对齐

常见错误是梯度方向写成45deg后发现斜边歪了、长度不够,或者在高缩放/高DPI屏上出现模糊锯齿。关键在三点:

  • background-image: linear-gradient(135deg, transparent 10px, #fff 10px)——角度得是135deg315deg,对应从左下到右上或右下到左上的斜切
  • 透明段和实色段的长度(如10px)必须一致,否则斜边会虚化或错位
  • 伪元素宽高要刚好卡住折角区域,比如右上折角,width设为20pxheight设为20px,再用transform: rotate(45deg)反而难控,不如直接定位+梯度裁剪

示例(右上折角):

div.tag::after {   content: '';   position: absolute;   top: 0; right: 0;   width: 24px; height: 24px;   background: linear-gradient(135deg, transparent 12px, #f0f0f0 12px); }

盒模型留白和z-index顺序决定是否露底

折角常被父容器背景盖住,或把内容文字顶开——问题不在渐变本身,而在盒模型没预留空间:

立即学习前端免费学习笔记(深入)”;

  • 父元素padding必须避开折角区域,比如右上折角,padding-rightpadding-top至少留出24px
  • 伪元素z-index必须低于内容层(如文字),否则会遮字;但又要高于父背景,否则看不到斜边
  • 若父元素有overflow: hidden,折角伪元素会被裁掉,必须移除或改用overflow: visible

移动端适配时px值会失准

折角大小写死12pxiphone上看着太小,在ipad上又太粗。更稳妥的方式是用remclamp()动态缩放:

div.tag::after {   width: clamp(16px, 3vw, 24px);   height: clamp(16px, 3vw, 24px);   background: linear-gradient(135deg, transparent 50%, #f0f0f0 50%); }

注意:50%在这里替代固定像素,让斜边始终居中劈开伪元素,避免因缩放导致比例失调。

折角最难调的其实是边缘过渡——稍有偏差,斜边就发虚或漏白,多试两组transparent/color长度组合,比调角度更有效。

text=ZqhQzanResources