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 阴影悬浮边框 的设置方法,让你的网页更加生动! 🚀 如果有任何问题,欢迎在评论区交流! 😊

相关推荐
lichenyang45313 分钟前
鸿蒙 Stage 模型到底是什么?一篇讲清 Ability、EntryAbility 和入口文件为什么这么设计
前端
ihuyigui29 分钟前
国际商超零售短信接口
大数据·前端·后端·架构·零售
Yan-英杰29 分钟前
从零玩转搜索引擎 API: 多引擎整合实战
服务器·前端·microsoft
Spider_Man34 分钟前
Claude Code Hooks:给 AI 助手装上"安全带"
前端·ai编程·claude
lichenyang45339 分钟前
HarmonyOS 6.0 ArkUI 循环渲染:ForEach、LazyForEach 和 Repeat 到底怎么选?
前端
Captaincc1 小时前
置身钉内:一个 AI 办公产品的理想、失焦与组织困境
前端·程序员
零陵上将军_xdr1 小时前
后端转全栈学习-Day6-JavaScript 基础-4
前端·javascript·学习
梦幻通灵2 小时前
Vue3 Element日期控件置灰明天之后日期
前端·javascript·vue.js
lzhdim2 小时前
C盘空间多出来4GB:谷歌服软 Chrome本地AI大模型可禁用、删除了
前端·人工智能·chrome
Monkery2 小时前
WWDC26 全面汇总
前端·人工智能