css3 实现盒子四周光晕_【css炫酷动画】css3完成盒子缺角动画

b18a3c691fa54d4668d6715cf94ea0d5.png

点击上方 蓝字 关注我们

b09a7669a3e8a0b9f809e37e7da456fb.png a48b668a92121275e19bf99a9c3499ab.png

今天分享一个用 css3 来实现的盒子缺角动画,并且鼠标移动上去以后,缺角会自动折叠回去,形成一个完整的盒子。下面先来看一下成品图

24f6f2907a5cf06a2fad0d78d383e92b.gif

标签元素部分
<body>    <div class="folding">折叠动画div>body>
具体样式
<style>        @keyframes folding {            0% {                transform: rotate3d(1, 1, 0, 180deg);                box-shadow: .05em -.05em .1em rgba(0,0,0,.15);            }            10% {                transform: rotate3d(1, 1, 0, 160deg);                box-shadow: .05em -.05em .1em rgba(0,0,0,.15);            }            20% {                transform: rotate3d(1, 1, 0, 140deg);                box-shadow: .05em -.05em .1em rgba(0,0,0,.15);            }            30% {                transform: rotate3d(1, 1, 0, 120deg);                box-shadow: .05em -.05em .1em rgba(0,0,0,.15);            }            40% {                transform: rotate3d(1, 1, 0, 100deg);                box-shadow: .05em -.05em .1em rgba(0,0,0,.15);            }            50% {                transform: rotate3d(1, 1, 0, 80deg);                box-shadow: .05em -.05em .1em rgba(0,0,0,.15);            }            60% {                transform: rotate3d(1, 1, 0, 60deg);                box-shadow: .05em -.05em .1em rgba(0,0,0,.15);            }            70% {                transform: rotate3d(1, 1, 0, 40deg);                box-shadow: .05em -.05em .1em rgba(0,0,0,.15);            }            90% {                transform: rotate3d(1, 1, 0, 20deg);                box-shadow: .05em -.05em .1em rgba(0,0,0,.15);            }            100% {                transform: rotate3d(1, 1, 0, 0deg);                box-shadow: 0 0 0 0;            }        }        .folding{            margin: 0 auto;            position: relative;            width: 200px;            height: 80px;            border-radius: 10px;            color: #fff;            line-height: 80px;            text-align: center;            background: linear-gradient(-135deg,transparent 1.5em, #58a 0);            cursor: pointer;        }        .folding:hover:before{            transform: rotate3d(1, 1, 0, 0deg);            animation: folding .5s ease;            box-shadow: 0 0 0 0;            border-bottom-left-radius: inherit;        }        .folding::before{            content: "";            position: absolute;            top: 0;            right: 0;            background: linear-gradient(to left bottom, #58a 50%,transparent 50%) 100% 0 no-repeat;            width: 2.12134em;            height: 2.12134em;            transform: rotate3d(1, 1, 0, 180deg);            transform-origin: bottom right;            border-top-right-radius: inherit;            box-shadow: .05em -.05em .1em rgba(0,0,0,.15);        }style>
完整代码
<html lang="en"><head>    <meta charset="UTF-8">    <title>盒子缺角效果title>    head><body>       <style>        @keyframes folding {            0% {                transform: rotate3d(1, 1, 0, 180deg);                box-shadow: .05em -.05em .1em rgba(0,0,0,.15);            }            10% {                transform: rotate3d(1, 1, 0, 160deg);                box-shadow: .05em -.05em .1em rgba(0,0,0,.15);            }            20% {                transform: rotate3d(1, 1, 0, 140deg);                box-shadow: .05em -.05em .1em rgba(0,0,0,.15);            }            30% {                transform: rotate3d(1, 1, 0, 120deg);                box-shadow: .05em -.05em .1em rgba(0,0,0,.15);            }            40% {                transform: rotate3d(1, 1, 0, 100deg);                box-shadow: .05em -.05em .1em rgba(0,0,0,.15);            }            50% {                transform: rotate3d(1, 1, 0, 80deg);                box-shadow: .05em -.05em .1em rgba(0,0,0,.15);            }            60% {                transform: rotate3d(1, 1, 0, 60deg);                box-shadow: .05em -.05em .1em rgba(0,0,0,.15);            }            70% {                transform: rotate3d(1, 1, 0, 40deg);                box-shadow: .05em -.05em .1em rgba(0,0,0,.15);            }            90% {                transform: rotate3d(1, 1, 0, 20deg);                box-shadow: .05em -.05em .1em rgba(0,0,0,.15);            }            100% {                transform: rotate3d(1, 1, 0, 0deg);                box-shadow: 0 0 0 0;            }        }        .folding{            margin: 0 auto;            position: relative;            width: 200px;            height: 80px;            border-radius: 10px;            color: #fff;            line-height: 80px;            text-align: center;            background: linear-gradient(-135deg,transparent 1.5em, #58a 0);            cursor: pointer;        }        .folding:hover:before{            transform: rotate3d(1, 1, 0, 0deg);            animation: folding .5s ease;            box-shadow: 0 0 0 0;            border-bottom-left-radius: inherit;        }        .folding::before{            content: "";            position: absolute;            top: 0;            right: 0;            background: linear-gradient(to left bottom, #58a 50%,transparent 50%) 100% 0 no-repeat;            width: 2.12134em;            height: 2.12134em;            transform: rotate3d(1, 1, 0, 180deg);            transform-origin: bottom right;            border-top-right-radius: inherit;            box-shadow: .05em -.05em .1em rgba(0,0,0,.15);        }style>        <div class="folding">折叠动画div>body>html>

关注我,带你每天了解一个 css3 炫酷小动画

往期动画文章

  1. 【每日一更】css3炫酷文字入场动画

  2. 【每日一更】css3发光盒子动画

  3. 【每日一更】css3 抖动文字动画

f395783b94d16d20c8807dc1bb0a1f6c.gif

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值