详解纯CSS实现多彩、智能阴影的方法

本篇文章给大家详细介绍一下纯css实现多彩、智能阴影的方法。有一定的参考价值,有需要的朋友可以参考一下,希望对大家有所帮助。

详解纯CSS实现多彩、智能阴影的方法

有没有想过如何创建从前景元素中继承某些颜色的阴影效果?阅读本文并找出如何实现方法吧!

前几天我经过家得宝(Home Depot,美国家得宝公司,全球领先的家居建材用品零售商),他们正在大规模展销正在出售的智能灯,其中一种是一系列灯泡位于电视机后面,它们会投射出与电视机前景屏幕上显示的颜色相近的灯光,类似于以下图片所示。

1.png

注意电视后面发生了什么。电视机屏幕前景中显示的颜色被灯投影成彩色阴影背景。随着屏幕上颜色的变化,背景投影颜色也发生变化。真的很酷,对吧?

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

看到这一点后,自然而然地我首先想到的是,能否使用 web 开发技术创建一个五颜六色的,并且足够聪明可以模拟前景颜色的阴影呢?事实证明,在只使用 CSS 的情况下,完全可以实现这种效果。在本文中,我们将研究如何实现。【学习视频分享:css视频教程】

开干!

令其成真

在接下来的段落中你将会发现,刚开始时,乍一看仅使用 CSS 来创建智能的彩色阴影似乎是一项艰巨的任务,当我们循序渐进,把困难部分拆分成更小的部分时,你就会发现一切都会变得容易理解消化。在接下来的章节中,我们将创建一个如下所示的示例:

2.gif

你看到的是一张寿司的图片,后面有与前景颜色相对应的阴影。为了强调我们所做的是动态的,给阴影增加了一个脉动动画效果。通过这个有效的示例,让我们深入探讨如何仅在使用 HTMLCSS 的情况下让一切变得生动起来。

展示图片

用于展示寿司的 HTML 如下所示并没有什么特别:

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

.sushi {  margin: 100px;  width: 150px;  height: 150px;  background-image: url("https://www.kirupa.com/icon/1f363.svg");  background-repeat: no-repeat;  background-size: contain;}

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

3.png

创建阴影

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

直接位于图片所在 div 的后面;继承与父元素相同的背景图像;通过滤镜产生出多彩的 drop-shadow 阴影效果。

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

.colorfulShadow {  position: relative;}.colorfulShadow::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,这意味着它将继承父级元素的背景值:

background: inherit;

filter 属性定义了两个滤镜值:drop-shadowblur

filter: drop-shadow(0px 0px 10px rgba(0, 0, 0, 0.50)) blur(20px);

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

4.png

到这一点,我们已经实现了很多。为了完整性,如果你想要多彩的阴影具有放大缩小的动画效果,以下额外的 CSS 可以帮你实现:

.colorfulShadow {  position: relative;}.colorfulShadow::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 来创建通常在 HTMLJavaScript 领域内完成的元素创建任务。对于我们多彩的智能阴影来说,我们依赖于父元素有一个背景图像集,这使得我们定义一个既可以继承父级背景细节又可以设置模糊效果和投影效果的子元素变得容易。虽然这一切都很好,减少了我们大量的复制粘贴工作,但是这种方法也不是很灵活。

如果我想将这样的阴影应用到一个不只是带有背景图像的空元素上,该怎么办呢?如果我有一个 HTML 元素如一个按钮或组合框,我想应用这种阴影效果呢?一种解决方案是依靠  JavaScript 复制 DOM 中的相应元素,将其放置在前台元素底层,应用过滤器,这样也是一种方法。虽然这可以实现效果,但我想到这个有点重复 DOM 元素的沉重过程就不寒而栗。更糟糕的是,JavaScript 没有将你想提供的任意视觉意向转换为渲染目标位图的能力!

更多编程相关知识,请访问:编程视频!!

以上就是详解纯CSS实现多彩、智能阴影的方法的详细内容,更多请关注创想鸟其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/1620077.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2025年12月24日 06:58:16
下一篇 2025年12月21日 02:53:28

相关推荐

  • css bfc是什么意思

    在css中,bfc中文意思为“块级格式化上下文”,是Web页面中盒模型布局的CSS渲染模式,指一个独立的渲染区域或者说是一个隔离的独立容器。块格式化上下文包含创建它的元素内部的所有内容。 本教程操作环境:windows7系统、CSS3&&HTML5版、Dell G3电脑。 何为BFC…

    2025年12月24日 好文分享
    000
  • 如何提升css性能

    提升方法: 1、将样式写在css文件中,在head中引用;2、不使用“@import”;3、避免使用复杂的选择器,层级越少越好;4、精简页面的样式文件;5、利用CSS继承减少代码量;6、慎重使用浮动、定位属性;7、标准化各种浏览器前缀等。 本教程操作环境:windows7系统、CSS3版、Dell …

    2025年12月24日
    000
  • css怎么设置div阴影

    在css中,可以使用box-shadow属性来给设置div阴影,只需要给div元素添加“box-shadow: 水平阴影值 垂直阴影值 模糊距离 阴影大小 阴影颜色 inset;”样式即可;其中“inset”值,可省略,它是设置内阴影的。 本教程操作环境:windows7系统、CSS3&&a…

    2025年12月24日
    000
  • css实现三列布局有哪些方法

    css实现三列布局的方法:1、float浮动布局;2、绝对定位布局;3、flexbox弹性布局,存在IE上兼容性问题,只能支持IE9以上;4、table表格布局,不利于搜索引擎抓取信息;5、gird网格布局,兼容性差。 本教程操作环境:windows7系统、CSS3&&HTML5版、…

    2025年12月24日
    000
  • css怎么设置左边距

    css设置左边距的方法:1、使用margin-left属性,可以设置元素的左外边距,语法格式“margin-left:边距值;”;2、使用padding-left属性,可以设置元素的左内边距,语法格式“padding-left:边距值;”。 本教程操作环境:windows7系统、CSS3&&…

    2025年12月24日
    000
  • css怎么设置滚动条的高度

    css设置滚动条高度的方法:首先使用“::-webkit-scrollbar”选择器选中整个滚动条,然后使用height属性设置滚动条的高度,语法格式“::-webkit-scrollbar{height:高度值;}”。 本教程操作环境:windows7系统、CSS3&&HTML5版…

    2025年12月24日
    000
  • css怎么设置字体颜色渐变

    css设置字体颜色渐变的方法:1、使用“background-cli”和“text-fill-color”实现字体颜色渐变;2、使用“mask-imag”设置字体颜色渐变;3、使用“linearGradient、fill”设置字体颜色渐变。 本文操作环境:windows7系统、CSS3版,DELL …

    2025年12月24日
    000
  • css怎么实现响应式布局

    css实现响应式布局的方法:1、使用flex布局,优点是代码简单、布局方便;2、使用绝对布局,结合使用media可以实现响应式布局;3、使用grid布局,优点是写法简便;4、使用float布局,优点是兼容性比较好。 本教程操作环境:windows7系统、CSS3&&HTML5版、De…

    2025年12月24日 好文分享
    000
  • css怎么设置字母大写

    css中可以使用text-transform属性设置字母大写,语法格式为“text-transform:capitalize|uppercase;”;其中值“capitalize”可设置首字母大写,值“uppercase”可设置字母全大写。 本教程操作环境:windows7系统、CSS3&&…

    2025年12月24日
    000
  • css怎么设置分割线

    css设置分割线的方法:首先创建一个HTML实例文件;然后在body中创建三个div;最后给第二个div设置样式为“padding-top:3px;width:40%;border-top:1px solid #666666;”即可。 本文操作环境:windows7系统、HTML5&&amp…

    2025年12月24日
    000
  • css怎么隐藏元素但保留位置

    在css中,可以使用visibility属性来隐藏元素但保留元素位置,只需要给元素设置“visibility: hidden;”样式即可;这样元素会被隐藏,但是不会消失,依然占据空间,隐藏后不会改变html原有样式。 本教程操作环境:windows7系统、CSS3&&HTML5版、D…

    2025年12月24日
    000
  • css如何改变图片颜色

    css改变图片颜色的方法:1、使用【mix-blend-mode】方法进行取值;2、通过【background-blend-mode: lighten】这个混合模式实现改变图片主体颜色黑色为其它颜色的目的。 本教程操作环境:windows7系统、css3版,DELL G3电脑。 css改变图片颜色的…

    2025年12月24日
    000
  • css如何禁止滑动

    css禁止滑动的方法:1、在【】里加入【scroll=”no”】,可隐藏滚动条;2、指当浏览器窗口宽度或高度大于页面的宽或高时,不显示滚动条;3、在【】里加入【style=”overflow-x:hidden”】。 本教程操作环境:windows7系统…

    2025年12月24日
    000
  • css如何禁止复制

    css禁止复制的方法是通过【user-select】属性设置不可复制的css代码,语法【user-select:none |text| all | element】。 本教程操作环境:windows7系统、css3版,DELL G3电脑。 css禁止复制的方法: 通过user-select属性设置不…

    2025年12月24日
    000
  • 8个值得了解的CSS性能优化小技巧

    本篇文章给大家介绍一下css性能优化的8个技巧。有一定的参考价值,有需要的朋友可以参考一下,希望对大家有所帮助。 我们都知道对于网站来说,性能至关重要,CSS作为页面渲染和内容展现的重要环节,影响着用户对整个网站的第一体验。因此,与其相关的性能优化是不容忽视的。 对于性能优化我们常常在项目完成时才去…

    2025年12月24日
    000
  • css如何设置图片不重复拉伸

    在css中,可以通过设置background-repeat属性的值为“no-repeat”来设置图片不重复拉伸。background-repeat属性可以设置背景图片是否重复以及如何重复,当值为“no-repeat”时设置不重复拉伸。 本教程操作环境:windows7系统、CSS3&&amp…

    2025年12月24日
    000
  • 如何只用css实现点击按钮切换图片

    在css中,可以使用“:target”选择器,配合display属性来实现点击按钮切换图片,只需要给元素设置“元素:target{display:block;}”语句即可。“:target”选择器可用于选取当前活动的目标元素。 本教程操作环境:windows7系统、HTML5&&CS…

    2025年12月24日
    000
  • css怎么实现图片居中

    css实现图片居中的方法:1、利用“margin:0 auto”或“text-align:center”样式实现图片水平居中;2、利用“高==行高”实现图片垂直居中;3、利用table实现图片垂直居中;4、利用绝对定位实现图片垂直居中。 本教程操作环境:windows7系统、CSS3&&am…

    2025年12月24日
    000
  • css如何设置背景图片位置

    在css中,可以使用background-position属性来设置背景图片位置,该属性可以设置背景图像的起始位置,进行背景图片的定位。background-position属性需要有两个值,分别控制水平和垂直方向上的定位。 本教程操作环境:windows7系统、CSS3&&HTML…

    2025年12月24日 好文分享
    000
  • css怎么设置悬浮效果

    css设置悬浮效果的方法:首先给元素添加“position: fixed;”样式,固定元素的位置,让元素悬浮在页面中,不随浏览器窗口的滚动条滚动而变化;然后使用top、bottom、left、right属性设置元素的悬浮位置即可。 本教程操作环境:windows7系统、CSS3&&H…

    2025年12月24日
    000

发表回复

登录后才能评论
关注微信