CSS 和 SVG 实现彩色图片阴影
创始人
2025-07-12 00:31:32
0

在平时开发中,有时候会碰到这样的彩色阴影,效果如下:

是不是非常有质感?下面分别介绍 CSS 和 SVG 两种实现方式,一起看看吧!

一、实现原理

从设计上看,其实原理很简单,一张原图和一张模糊的图,叠加在一起就行了,示意如下:

那么具体如何实现呢?接着往下看。

二、CSS 滤镜

首先,单纯的 CSS并不能直接做出这种效果,毕竟无法生成一份相同的图片,因此,我们需要手动创建一个相同的图层。

假设HTML如下:

为了节省 dom,我们可以通过伪元素的方式来生成这个图片,关键代码如下:

.wrap{
  position: relative;
  /**/
}
.wrap::before{
  content:'';
  position: absolute;
  background: url("https://bookcover.yuewen.com/qdbimg/349573/1036370336/180.webp");
  transform: translate(10px,10px);
}

稍微给点偏移,这样得到了两层图片。

然后给这个伪元素设置模糊滤镜就行了。

.wrap::before{
  /**/
  filter: blur(12px);
}

这样就实现了文章开头效果。

是不是很简单呢?

不过实际中可以采用 CSS变量的方式,将需要重复的图片抽离出来。

然后CSS就可以保持统一了。

.wrap::before{
  /**/
  background: var(--bg);
}

三、SVG滤镜

有没有发现 上面这种方式需要手动去创建一个一模一样的图层有些多余呢?

确实是这样,CSS 目前还无法直接复制一个图层。

Firefox 中有个element()方法可以根据dom生成一份完全相同的图层,但是仅仅 Firefox 支持:https://developer.mozilla.org/en-US/docs/Web/CSS/element。

那么,还有其他方式吗?

当然也是有了,那就是 SVG滤镜!

和前面的思路其实是一致的,先模糊图层,然后偏移一下,用SVG实现就是。


  
    
    
    
      
      
    
  

似乎有些看不懂?没关系,我们一步步分析。

首先filter就滤镜的意思,表示整个就是定义了一个滤镜,后面可以给 CSS 直接使用。

接着,feGaussianBlur就是高斯模糊,stdDeviation表示模糊的范围。

然后,feOffset表示偏移,dx和dy分别是水平和垂直方向的位移。

最后是一个feMerge标签,这个表示合并,也就是将多个滤镜组合起来,里面的feMergeNode表示每一步滤镜的结果。这里有两个feMergeNode,第一个就是前面滤镜的最终结果,也就是「模糊」+「偏移」后的效果,第二个feMergeNode有一个in参数,表示输入,这里设置的是SourceGraphic,表示原始图像,也就是处理之前的原图。这里的叠加顺序是后来居上,也就是原图放在模糊图之上。

示意效果如下:

最后,我们在CSS中直接通过 id 引入的方式使用这个滤镜就行了。

.wrap{
  filter: url("#natural-shadow-filter");
}

效果如下,和 CSS基本一致。

我们还可以多试几种其他图片,下面是 CSS 和 SVG 两种实现的效果对比。

你可以查看以下链接

  • CSS & SVG color shadow(code.juejin)[1]
  • CSS & SVG color shadow(codepen.io)[2]

四、总结一下

以上就是本文的全部内容了,主要介绍了 CSS 和 SVG 两种不同的实现方式,下面总结一下

  • 彩色阴影其实原理很简单,一张原图和一张模糊的图,叠加在一起就行了。
  • CSS无法直接创建一个完全相同的图层,需要手动去创建。
  • 手动去创建一个一模一样的图层有些多余,而SVG可以自动生成多份。
  • SVG可以将多个效果通过feMerge进行叠加,顺序是后来居上,SourceGraphic表示原始图像。
  • CSS可以通过url(#id)的方式引入SVG滤镜。

当然,SVG的潜力远不仅如此,在图像处理方面,SVG有着无可比拟的优势,CSS 滤镜可以称之为“残血版”滤镜,很多效果还是需要SVG出马,以后还会介绍更多实用场景。

[1]CSS & SVG color shadow (code.juejin): https://code.juejin.cn/pen/7328684301011124260。

[2]CSS & SVG color shadow (codepen.io): https://code.juejin.cn/pen/7328684301011124260。

相关内容

热门资讯

PHP新手之PHP入门 PHP是一种易于学习和使用的服务器端脚本语言。只需要很少的编程知识你就能使用PHP建立一个真正交互的...
网络中立的未来 网络中立性是什... 《牛津词典》中对“网络中立”的解释是“电信运营商应秉持的一种原则,即不考虑来源地提供所有内容和应用的...
各种千兆交换机的数据接口类型详... 千兆交换机有很多值得学习的地方,这里我们主要介绍各种千兆交换机的数据接口类型,作为局域网的主要连接设...
什么是大数据安全 什么是大数据... 在《为什么需要大数据安全分析》一文中,我们已经阐述了一个重要观点,即:安全要素信息呈现出大数据的特征...
全面诠释网络负载均衡 负载均衡的出现大大缓解了服务器的压力,更是有效的利用了资源,提高了效率。那么我们现在来说一下网络负载...
粉嫩如何诠释霸道 东芝M805... “霸道粉”是个什么玩意东芝M805拿过来的时候,笔者扑哧笑了,不是笑这款笔记本,而是笑这款产品的颜色...
如何允许远程连接到MySQL数... [[277004]]【51CTO.com快译】默认情况下,MySQL服务器仅侦听来自localhos...
30分钟搞定iOS自定义相机 最近公司的项目中用到了相机,由于不用系统的相机,UI给的相机切图,必须自定义才可以。就花时间简单研究...
如何利用交换机和端口设置来管理... 在网络管理中,总是有些人让管理员头疼。下面我们就将介绍一下一个网管员利用交换机以及端口设置等来进行D...
P2P的自白|我不生产内容,我... 现在一提起P2P,人们就会联想到正在被有关部门“围剿”的互联网理财服务。×租宝事件使得劳...