css filter: drop-shadow 高级阴影效果

CSS 中的阴影效果主要通过 box-shadow 和 text-shadow 实现。它们分别用于为元素的边框和文字添加阴影效果。以下是它们的详细用法和示例:

1. box-shadow:元素阴影
box-shadow 用于为块级元素添加阴影,支持多种参数控制阴影的样式。

语法

box-shadow: [水平偏移] [垂直偏移] [模糊半径] [扩展半径] [颜色];
  • 水平偏移(必选):阴影在水平方向的位移(正值向右,负值向左)。
  • 垂直偏移(必选):阴影在垂直方向的位移(正值向下,负值向上)。
  • 模糊半径(可选):控制阴影的模糊程度(值越大越模糊,默认为 0)。
  • 扩展半径(可选):控制阴影的扩展范围(正值扩展,负值收缩)。
  • 颜色(可选):阴影的颜色(支持任何有效的颜色值,如 rgba、# 等)。

示例

/* 基本阴影 */
div {
  box-shadow: 10px 10px 20px rgba(0, 0, 0, 0.5);
}

/* 内阴影 */
div {
  box-shadow: inset 5px 5px 10px rgba(0, 0, 0, 0.3);
}

/* 多重阴影 */
div {
  box-shadow: 5px 5px 15px rgba(0, 0, 0, 0.5), -5px -5px 10px rgba(255, 255, 255, 0.8);
}

2. text-shadow:文字阴影
text-shadow 用于为文字添加阴影效果,语法与 box-shadow 类似,但没有扩展半径参数。

语法

text-shadow: [水平偏移] [垂直偏移] [模糊半径] [颜色];
  • 水平偏移:阴影在水平方向的位移。
  • 垂直偏移:阴影在垂直方向的位移。
  • 模糊半径(可选):控制阴影的模糊程度。
  • 颜色(可选):阴影的颜色。

示例

/* 基本文字阴影 */
h1 {
  text-shadow: 2px 2px 5px rgba(0, 0, 0, 0.5);
}

/* 多重文字阴影 */
h1 {
  text-shadow: 2px 2px 5px rgba(0, 0, 0, 0.5), -2px -2px 5px rgba(255, 255, 255, 0.8);
}

/* 霓虹灯效果 */
h1 {
  text-shadow: 0 0 5px #ff00ff, 0 0 10px #ff00ff, 0 0 20px #ff00ff;
}

3. filter: drop-shadow() 一种高级阴影效果

filter: drop-shadow() 是 CSS 中的一种高级阴影效果,与 box-shadow 类似,但有更灵活的应用场景。它主要用于为元素(尤其是图像或透明背景元素)添加阴影效果,并能跟随元素的轮廓形状,而不仅限于矩形边框。

drop-shadow 的语法

filter: drop-shadow(offset-x offset-y blur-radius color);
  • offset-x:阴影的水平偏移量(正值向右,负值向左)。
  • offset-y:阴影的垂直偏移量(正值向下,负值向上)。
  • blur-radius:模糊半径(可选,默认值为 0,值越大越模糊)。
  • color:阴影颜色(可选,默认是元素的文本颜色)。

示例解析:filter: drop-shadow(0 0 10px #fff)

  • 0 0:阴影没有水平或垂直偏移。
  • 10px:模糊半径为 10 像素,阴影边缘柔和。
  • #fff:阴影颜色为白色。

该效果通常用于创建发光效果,尤其适用于深色背景或需要突出显示的元素。

发光按钮

<!DOCTYPE html>
<html lang="en">
<head>
  <meta charset="UTF-8">
  <meta name="viewport" content="width=device-width, initial-scale=1.0">
  <title>Drop Shadow Example</title>
  <style>
    button {
      padding: 10px 20px;
      font-size: 18px;
      color: #fff;
      background-color: #000;
      border: none;
      border-radius: 5px;
      cursor: pointer;
      filter: drop-shadow(0 0 10px #fff);
      transition: filter 0.3s ease;
    }

    button:hover {
      filter: drop-shadow(0 0 20px #00f);
    }
  </style>
</head>
<body style="background-color: #333; display: flex; justify-content: center; align-items: center; height: 100vh;">
  <button>Glow Button</button>
</body>
</html>

发光图片

<!DOCTYPE html>
<html lang="en">
<head>
  <meta charset="UTF-8">
  <meta name="viewport" content="width=device-width, initial-scale=1.0">
  <title>Drop Shadow Image</title>
  <style>
    img {
      width: 200px;
      filter: drop-shadow(0 0 15px #fff);
      transition: filter 0.3s ease;
    }

    img:hover {
      filter: drop-shadow(0 0 30px #0ff);
    }
  </style>
</head>
<body style="background-color: #000; display: flex; justify-content: center; align-items: center; height: 100vh;">
  <img src="https://via.placeholder.com/200" alt="Glowing Image">
</body>
</html>

注意事项

  1. 透明区域支持:drop-shadow 会考虑元素的透明部分,而 box-shadow 不会。
  2. 性能影响:filter 属性可能会对性能有轻微影响,尤其是在动画中频繁使用时。
  3. 浏览器兼容性:drop-shadow 在现代浏览器(如 Chrome、Firefox、Edge、Safari)中支持良好,但在 IE 中不支持。

上一篇:Vue工具和面试题目(二)


下一篇:Spring Boot 实现防盗链功能