一文搞懂 CSS 切角与折角效果:从渐变到逼真翻折(附完整代码示例)

在网页设计中,我们经常希望让卡片、便签等元素看起来更立体、更有质感。今天我们就来深入学习一个高级但实用的 CSS 技巧——CSS 切角与折角效果(Folded Corner),并带你从渐变原理到实战优化,一步步实现“逼真的折角便签”视觉效果。


💡 一、什么是切角与折角?

  • 切角(Cut Corner):指通过CSS渐变在元素的某个角上“切”掉一部分,形成一个斜角。

  • 折角(Folded Corner):在切角的基础上,加入暗面阴影,让这个角看起来像是“翻折”起来的纸张。

下图展示了我们将要实现的几种效果(从简单到逼真):

效果说明
   45° 切角及优化
  30° 切角效果
实际生活中的折角效果(带阴影、立体感)

🧩 二、核心原理讲解

CSS 实现切角的核心是使用 线性渐变(linear-gradient)。通过透明色与背景色的交替,可以让元素的一部分看起来被“切掉”或“折叠”了。

例如:

background: linear-gradient(-135deg, transparent 2em, #58a 0);

这行代码的意思是:

  • -135° 方向开始渐变;

  • 2em 部分是透明;

  • 接下来为背景色 #58a

  • 于是形成了一个 45° 的斜切角。


🧱 三、完整案例代码讲解

以下是完整的可运行代码(建议复制后直接在浏览器中打开查看效果👇):

<!DOCTYPE html>
<!--CSS变形,CSS渐变,“切角效果”-->
<html>

<head>
    <meta charset="utf-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <title>CSS 切角与折角效果</title>
    <meta name="description" content="">
    <meta name="viewport" content="width=device-width, initial-scale=1">
    <style>
        html {
            width: 100%;
            height: 100%;

        }
         /* 图一:45°基础切角 */
        #test1 {
            width: 300px;
            height: 200px;
            background: #58a;
            background: linear-gradient(to left bottom,
                    transparent 50%, rgba(0, 0, 0, .4) 0) no-repeat 100% 0 / 2em 2em,
                linear-gradient(-135deg, transparent 2em, #58a 0);
        }
        /* 图二:调整尺寸匹配 */
        #test2 {
            width: 300px;
            height: 200px;
            margin-top: 20px;
            background: #58a;
            background: linear-gradient(to left bottom,
                    transparent 50%, rgba(0, 0, 0, .4) 0) no-repeat 100% 0 / 2em 2em,
                linear-gradient(-135deg, transparent 1.5em, #58a 0);
        }
         /* 图三:改为 30° 切角 */
        #test3 {
            width: 300px;
            height: 200px;
            margin-top: 20px;
            background: #58a;
            background: linear-gradient(to left bottom,
                    transparent 50%, rgba(0, 0, 0, .4) 0) no-repeat 100% 0 / 2em 2em,
                linear-gradient(-150deg,
                    transparent 1.5em, #58a 0);
        }
        /* 图四:通过三角函数调整折角比例 */
        #test4 {
            width: 300px;
            height: 200px;
            margin-top: 20px;
            background: #58a;
            background: linear-gradient(to left bottom,
                    transparent 50%, rgba(0, 0, 0, .4) 0) no-repeat 100% 0 / 3em 1.73em,
                linear-gradient(-150deg,
                    transparent 1.5em, #58a 0);
        }

        /* 图五:真实折角便签效果 */
         #note {
            margin-top: 10px;
            width: 260px;
            height: 160px;
            padding: 20px 20px 20px 20px;
            position: absolute;
            top: 10px;
            right: 20px;
            background: #58a;
            background:
                linear-gradient(-150deg, transparent 1.5em, #58a 0);
            border-radius: .5em;
        }

        #note::before {

            content: '';
            position: absolute;
            top: 0;
            right: 0;
            background: linear-gradient(to left bottom,
                    transparent 50%, rgba(0, 0, 0, .4)0) 100% 0 no-repeat;
            width: 1.73em;
            height: 3em;
            transform: translateY(-1.3em) rotate(-30deg);
            transform-origin: bottom right;
            border-bottom-left-radius: inherit;
            box-shadow: -.2em .2em .3em -.1em rgba(0, 0, 0, .15);
        }
       
    </style>
</head>

<body>
    <div id="test1">图一:45°折角的解决方案</div>
    <div id="test2">图二:45°折角的解决方案</div>
    <div id="test3">图三:30°切角的解决方案</div>
    <div id="test4">图四:30°切角的解决方案</div>
    <div id="note">图五:实际生活中的30°切角的解决方案</div>
</body>

</html>

🧮 四、数学原理:折角比例的计算

当我们把角度改为 30° 时,折角的高和底边长度不再相等,需要通过三角函数计算:

  • 折角高(h) = size

  • 折角底(b) = size / tan(角度)

例如当角度 = 30°:

b = 2 / √3 ≈ 1.73em

这就是为什么在代码中使用:

background-size: 3em 1.73em;

来控制折角三角形的比例。


🎨 五、实现逼真翻折效果(::before伪元素)

为了让折角更有立体感,我们在右上角叠加一个“阴影三角形”:

#note::before {
  background: linear-gradient(to left bottom,
      transparent 50%, rgba(0, 0, 0, .4) 0);
  transform: translateY(-1.3em) rotate(-30deg);
  box-shadow: -.2em .2em .3em -.1em rgba(0, 0, 0, .15);
}

关键在于:

  • 阴影方向与角度匹配

  • transform顺序必须正确(先 translateYrotate);

  • 使用 transform-origin: bottom right; 来保持旋转中心在折角点。


🧰 六、SCSS 封装示例(让代码更 DRY)

如果你使用 Sass/SCSS,可以将折角封装成一个可复用的 Mixin:

@mixin folded-corner($background, $size, $angle: 30deg) {
  position: relative;
  background: $background;
  background: linear-gradient($angle - 180deg, transparent $size, $background 0);
  border-radius: .5em;

  $x: $size / sin($angle);
  $y: $size / cos($angle);

  &::before {
    content: '';
    position: absolute;
    top: 0; right: 0;
    background: linear-gradient(to left bottom, transparent 50%, rgba(0, 0, 0, .4) 0);
    width: $y; height: $x;
    transform: translateY($y - $x) rotate(2 * $angle - 90deg);
    transform-origin: bottom right;
    border-bottom-left-radius: inherit;
    box-shadow: -.2em .2em .3em -.1em rgba(0, 0, 0, .2);
  }
}

调用方式:

#note1 {
  @include folded-corner(#58a, 2em, 40deg);
}

🚀 七、总结

阶段关键技术效果提升
图一–图二linear-gradient + 渐变调整实现基础切角
图三–图四角度变化 + 三角函数计算更自然的切角比例
图五::before + 阴影 + transform实现逼真翻折

👉 通过这个案例,我们不仅掌握了 CSS 渐变的强大表现力,还了解了图形几何与视觉设计结合的魅力


🏁 八、结语

本文完整展示了从基础切角到逼真折角的实现路径。掌握这一技巧后,你可以轻松设计出像便签、卡片、标签等具有真实感的UI元素,为网页增添视觉层次。

🎯 建议收藏 + 实践!
下次做信息卡片、提示框、优惠券UI时,这个“折角技巧”一定能让你的页面更出彩✨。


如果你觉得本文对你有帮助,请一键 点赞 ❤️ 收藏 ⭐ 评论 💬 支持作者持续更新前端视觉特效系列!

内容概要:本文围绕在双母线系统中使用STATCOM进行无功补偿的技术方案展开,重点介绍了基于PI控制器的STATCOM控制系统设计Simulink仿真实现。文章详在双母线系统中使用STATCOM进行无功补偿,STATCOM的控制器基于PI控制器(Simulink仿真实现)细阐述了STATCOM的工作原理及其在提升电力系统电压稳定性、改善电能质量方面的关键作用,并通过构建双母线系统仿真模型验证了PI控制器对无功功率动态调节的有效性。文中涵盖了系统建模、控制器设计、参数整定及仿真结果分析等环节,展示了STATCOM在负载突变或系统扰动情况下快速响应无功需求、维持母线电压稳定的能力。; 适合人群:电力系统自动化、电气工程及相关专业的高校师生,从事电力电子无功补偿技术研究的科研人员,以及具备一定MATLAB/Simulink仿真基础的工程技术人员。; 使用场景及目标:①掌握STATCOM在电力系统中的无功补偿机制;②学习PI控制器在电力电子装置中的应用方法;③通过Simulink搭建双母线系统仿真模型,理解系统动态响应特性;④为实际工程项目中无功补偿装置的设计优化提供理论依据和技术参考。; 阅读建议:建议读者结合MATLAB/Simulink软件动手复现文中仿真模型,重点关注PI控制器参数调节对系统性能的影响,并尝试对比不同工况下的仿真结果,以深化对STATCOM控制策略的理解。同时可延伸学习先进控制算法(如模糊PID、自适应控制)在STATCOM中的应用,进一步提升系统控制精度鲁棒性。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

小九今天不码代码

感谢支持,一起进步~

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值