纯css实现阴影跳动

前言:能否使用 web 开发技术创建一个五颜六色的,并且足够聪明可以模拟前景颜色的阴影呢?事实证明,在只使用 CSS 的情况下,完全可以实现这种效果。在本文中,我们将研究如何实现。

图片实现

用于展示原图的 HTML 如下所示并没有什么特别(后台回复小站,获取原图):

<div class="parent">
    <div class="shadow logo"></div>
</div>

有一个父级 div 元素 .parent,它包含一个子级元素 .logo 用于展示图片。我们通过使用一张背景图片的形式来实例化,.logo 元素的具体样式如下:

.logo{
    margin: 100px auto;
    width: 300px;
    height: 300px;
    background-image: url("./kayako.svg");
    background-repeat: no-repeat;
    background-size: contain;
}

在上面样式规则中,我们将 div 设置为 300 * 300 宽高像素,并且设置了 background-image 及相关属性,展示一下我们现在所实现的结果。

阴影效果

现在我们已经展示出了我们的图片,剩下更加有趣的部分就是来定义阴影。我们将使用指定一个子伪元素 ::after 来定义阴影,它将做 3 件事情:

  • 直接位于图片所在 div 的后面;

  • 继承与父元素相同的背景图像;

  • 通过滤镜产生出多彩的 drop-shadow 阴影效果。

上述3个功能由以下2个样式规则实现:

.shadow {
    position: relative;
}
.shadow::after {
    content: "";
    width: 100%;
    height: 100%;
    position: absolute;
    background: inherit;
    background-position: center center;
    filter: drop-shadow(0px 0px 10px rgba(0, 0, 0, 0.50)) blur(20px);
    z-index: -1;
}

background 属性和 filter 属性

background 的值是 inherit,这意味着它将继承父级元素的背景值

filter 属性定义了两个滤镜值:drop-shadow 和 blur

我们的 drop-shadow 滤镜设置了一个 50% 透明度的黑色阴影。blur 滤镜为为元素设置 20px 的模糊效果。这两个滤镜的结合最终就可以创造出多彩的阴影,当这两个样式生效时,我们就可以看到如下图出现在图像后面彩色的阴影:

如果你想要多彩的阴影具有放大缩小的动画效果,额外的 CSS 可以帮你实现:

.shadow {
     position: relative;
}
.shadow::after {
    content: "";
    width: 100%;
    height: 100%;
    position: absolute;
    background: inherit;
    background-position: center center;
    filter: drop-shadow(0px 0px 10px rgba(0, 0, 0, 0.50)) blur(20px);
    z-index: -1;
    /* animation time! */
    animation: oscillate 1s cubic-bezier(.17, .67, .45, 1.32) infinite alternate;
    }
    @keyframes oscillate {  from {
        transform: scale(1, 1);
    }
    to {
        transform: scale(1.3, 1.3);
    }
}

如果你想在不使用循环动画效果的情况下增强交互性,也可以使用 CSS transition 来改变阴影的行为,如在 hover 操作情况下。需要强调的难点是对待伪元素只需要像对待用 HTML 创建的或 JavaScript 动态创建的元素一样,唯一的不同是这个元素完全是仅使用 CSS 创建的!

总结

伪元素允许我们使用 CSS 来创建通常在 HTML 和 JavaScript 领域内完成的元素创建任务。对于我们多彩的智能阴影来说,我们依赖于父元素有一个背景图像集,这使得我们定义一个既可以继承父级背景细节又可以设置模糊效果和投影效果的子元素变得容易。虽然这一切都很好,减少了我们大量的复制粘贴工作,但是这种方法也不是很灵活。

纯css实现阴影跳动,你学会了吗?

  • 4
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

前端e站

如果有所帮助,欢迎来杯奶茶

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

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

打赏作者

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

抵扣说明:

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

余额充值