HTML 如何设置 Div 阴影悬浮边框:从基础到进阶

在网页设计中,阴影(Shadow)悬浮效果(Hover Effect) 是提升交互体验和视觉层次感的重要手段。本文将详细介绍如何使用 HTML 和 CSS 为 <div> 元素添加 阴影效果 ,并结合 悬浮(Hover) 状态实现动态边框和阴影变化,让你的网页元素更加生动!


1. 基础:为 Div 添加静态阴影

1.1 使用 box-shadow 属性

box-shadow 是 CSS 中用于添加阴影的核心属性,语法如下:

css 复制代码
box-shadow: h-offset v-offset blur spread color inset;
  • h-offset:水平偏移(正值向右,负值向左)
  • v-offset:垂直偏移(正值向下,负值向上)
  • blur:模糊半径(值越大越模糊)
  • spread:扩散半径(正值扩大阴影,负值缩小阴影)
  • color :阴影颜色(支持 HEXRGBRGBA
  • inset(可选):内阴影(默认是外阴影)
示例:基础阴影
html 复制代码
<!DOCTYPE html>
<html>
<head>
    <style>
        .box {
            width: 200px;
            height: 100px;
            background: #3498db;
            margin: 50px;
            box-shadow: 10px 10px 15px rgba(0, 0, 0, 0.3);
        }
    </style>
</head>
<body>
    <div class="box"></div>
</body>
</html>

2. 进阶:悬浮时改变阴影和边框

2.1 使用 :hover 伪类实现交互效果

hover 伪类可以让元素在鼠标悬停时改变样式,常用于按钮、卡片等交互元素。

示例:悬浮时阴影变大
html 复制代码
<!DOCTYPE html>
<html>
<head>
    <style>
        .box {
            width: 200px;
            height: 100px;
            background: #3498db;
            margin: 50px;
            box-shadow: 5px 5px 10px rgba(0, 0, 0, 0.2);
            transition: box-shadow 0.3s ease; /* 添加过渡效果,使变化更平滑 */
        }
        .box:hover {
            box-shadow: 10px 10px 20px rgba(0, 0, 0, 0.4); /* 悬浮时阴影变大 */
        }
    </style>
</head>
<body>
    <div class="box"></div>
</body>
</html>

2.2 悬浮时添加边框

除了阴影,我们还可以在悬浮时添加 边框(border) 或改变边框颜色,增强交互感。

示例:悬浮时显示边框
html 复制代码
<!DOCTYPE html>
<html>
<head>
    <style>
        .box {
            width: 200px;
            height: 100px;
            background: #3498db;
            margin: 50px;
            box-shadow: 5px 5px 10px rgba(0, 0, 0, 0.2);
            transition: all 0.3s ease; /* 统一过渡效果 */
            border: 2px solid transparent; /* 默认透明边框 */
        }
        .box:hover {
            box-shadow: 10px 10px 20px rgba(0, 0, 0, 0.4);
            border: 2px solid #e74c3c; /* 悬浮时显示红色边框 */
        }
    </style>
</head>
<body>
    <div class="box"></div>
</body>
</html>

3. 高级:组合多种效果

3.1 内阴影 + 外阴影组合

我们可以同时使用 外阴影(默认)内阴影(inset 来创建更复杂的视觉效果。

示例:悬浮时内阴影 + 外阴影
html 复制代码
<!DOCTYPE html>
<html>
<head>
    <style>
        .box {
            width: 200px;
            height: 100px;
            background: #3498db;
            margin: 50px;
            box-shadow: 
                5px 5px 10px rgba(0, 0, 0, 0.2), /* 外阴影 */
                inset 0 0 10px rgba(255, 255, 255, 0.5); /* 内阴影(白色高光) */
            transition: all 0.3s ease;
        }
        .box:hover {
            box-shadow: 
                10px 10px 20px rgba(0, 0, 0, 0.4), /* 悬浮时外阴影变大 */
                inset 0 0 15px rgba(255, 255, 255, 0.8); /* 悬浮时内阴影更明显 */
            border: 2px solid #e74c3c; /* 悬浮时显示边框 */
        }
    </style>
</head>
<body>
    <div class="box"></div>
</body>
</html>

效果


3.2 3D 立体悬浮效果

通过调整 box-shadow 的偏移和模糊,可以模拟 3D 立体效果,让元素看起来像浮在页面上。

示例:3D 悬浮按钮
html 复制代码
<!DOCTYPE html>
<html>
<head>
    <style>
        .button {
            width: 150px;
            height: 50px;
            background: #3498db;
            color: white;
            border: none;
            border-radius: 5px;
            font-size: 16px;
            cursor: pointer;
            box-shadow: 0 5px 0 #2980b9; /* 底部阴影模拟 3D 效果 */
            transition: all 0.1s ease;
        }
        .button:hover {
            transform: translateY(-2px); /* 轻微上浮 */
            box-shadow: 0 7px 0 #2980b9; /* 阴影变大,增强 3D 感 */
        }
        .button:active {
            transform: translateY(2px); /* 点击时下沉 */
            box-shadow: 0 3px 0 #2980b9; /* 阴影变小 */
        }
    </style>
</head>
<body>
    <button class="button">点击我</button>
</body>
</html>

效果


4. 总结

效果 代码示例 适用场景
基础阴影 box-shadow: 5px 5px 10px rgba(0,0,0,0.2); 卡片、按钮、图片
悬浮阴影变化 :hover { box-shadow: 10px 10px 20px rgba(0,0,0,0.4); } 交互式元素
悬浮边框 :hover { border: 2px solid #e74c3c; } 按钮、卡片高亮
组合阴影 box-shadow: 5px 5px 10px rgba(0,0,0,0.2), inset 0 0 10px rgba(255,255,255,0.5); 高级 UI 设计
3D 效果 box-shadow: 0 5px 0 #2980b9; + transform: translateY(-2px); 按钮、悬浮菜单

5. 扩展阅读

希望本文能帮助你掌握 Div 阴影悬浮边框 的设置方法,让你的网页更加生动! 🚀 如果有任何问题,欢迎在评论区交流! 😊

相关推荐
lichenyang4533 小时前
Docker 学习笔记(一):为什么需要镜像、容器和仓库?
前端
kyriewen3 小时前
别再对着 TypeScript 报错发呆了:我把 10 个最常见的红色波浪线翻译成了人话
前端·javascript·typescript
IT_陈寒3 小时前
SpringBoot自动配置的坑,我的API突然就404了
前端·人工智能·后端
奇奇怪怪的4 小时前
Embedding 模型 10+ 横向评测
前端
陈广亮4 小时前
Monorepo 从 0 到 1 实操指南 2026 版:pnpm catalogs + Turborepo 2.x + changesets 全链路
前端
子兮曰4 小时前
OpenMontage 深度解剖:你的 AI 编程助手,其实是个视频工作室
前端·后端·ai编程
敲代码的鱼4 小时前
PDF 预览与签名批注写回 支持安卓 iOS 鸿蒙 UTS插件
android·前端·ios
子兮曰4 小时前
前端工具链的「Rust 化」:一场没有赢家的军备竞赛?
前端·后端·rust
Hyyy5 小时前
Function Calling / Tool Use的原理和实现模式
前端·llm·ai编程
爱勇宝5 小时前
从 Ctrl+CV 到 Enter:程序员正在失去什么
前端·后端·程序员