0

0

使用 CSS 圆形遮罩实现鼠标跟随的图片叠加揭示效果

花韻仙語

花韻仙語

发布时间:2026-02-15 15:05:11

|

810人浏览过

|

来源于php中文网

原创

使用 CSS 圆形遮罩实现鼠标跟随的图片叠加揭示效果

本文详解如何通过纯 css + javascript 实现“下层图片常驻、上层图片仅在鼠标悬停处以圆形(可带渐变)遮罩动态揭示”的交互效果,解决因绝对定位嵌套导致的图像偏移问题。

本文详解如何通过纯 css + javascript 实现“下层图片常驻、上层图片仅在鼠标悬停处以圆形(可带渐变)遮罩动态揭示”的交互效果,解决因绝对定位嵌套导致的图像偏移问题。

要实现「鼠标移动时,在固定位置的底层图片上,用一个可跟随光标的圆形窗口揭示上方图片」的效果,关键在于分离“遮罩容器”与“被揭示内容”的定位逻辑——不能将上层图片嵌套在移动的 .circle 内并设为 position: absolute,否则它会随 .circle 一起位移,导致始终只显示同一区域。

正确的思路是:
✅ 将两幅图片均作为 背景图(background-image) 分别应用在两个层级分明的 DOM 元素上;
✅ 底层容器(.container)承载下层图片,并设置 overflow: hidden 限制可见范围;
✅ 上层遮罩(.circle)是一个独立的、可自由移动的圆形 div,其自身设置上层图片为背景,通过 background-position 动态对齐视口;
✅ JavaScript 仅控制 .circle 的 left/top 坐标,使其中心始终锚定鼠标位置。

✅ 推荐 HTML 结构(语义清晰、无冗余嵌套)

<div class="container" style="background-image: url('lower.png')">
  <div class="circle" style="background-image: url('upper.png')"></div>
</div>

✅ 核心 CSS(重点:背景定位 + 居中控制)

.container {
  position: relative;
  width: 100vw;      /* 或具体尺寸,如 1920px */
  height: 100vh;      /* 或具体尺寸,如 1280px */
  background-size: cover;
  background-position: center;
  overflow: hidden;
  border-radius: 0;   /* 若需整体圆角可设,但非必须 */
}

.circle {
  position: absolute;
  width: 200px;       /* 遮罩直径 */
  height: 200px;
  border-radius: 50%;
  background-size: cover;
  background-position: center;
  /* 初始居中(可选),后续由 JS 覆盖 */
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  z-index: 2;
  /* 可选:添加内阴影或渐变蒙版增强视觉层次 */
  box-shadow: 0 0 0 9999px rgba(0,0,0,0.3);
}

/* 添加柔和渐变边缘(可选增强效果)*/
.circle::before {
  content: "";
  position: absolute;
  inset: 0;
  border-radius: 50%;
  background: radial-gradient(
    circle at center,
    transparent 0%,
    transparent 70%,
    rgba(0, 0, 0, 0.4) 100%
  );
}

? 注意:box-shadow 技巧(超大模糊半径遮罩)比 overflow: hidden 更可靠,能避免 .circle 移出容器时出现意外裁剪;若需严格限制在 .container 内,可改用 clip-path: circle(100px at var(--x) var(--y)) 配合 CSS 变量(现代浏览器支持)。

FlowMuse AI
FlowMuse AI

节点式AI视觉创作引擎

下载

✅ 精准跟随的 JavaScript(修正原逻辑缺陷)

const container = document.querySelector('.container');
const circle = document.querySelector('.circle');
const radius = 100; // 半径 = 宽高 / 2

container.addEventListener('mousemove', (e) => {
  const rect = container.getBoundingClientRect();
  const x = e.clientX - rect.left;
  const y = e.clientY - rect.top;

  // 设置 circle 的中心点为 (x, y),需减去半径实现“锚点居中”
  circle.style.left = `${x - radius}px`;
  circle.style.top = `${y - radius}px`;

  // 同步更新背景定位,确保上层图片内容随遮罩稳定呈现(关键!)
  circle.style.backgroundPosition = `${-x + radius}px ${-y + radius}px`;
});

? 为什么需要 backgroundPosition 动态调整?
因为 .circle 是移动的容器,而它的背景图(上层图片)默认以自身左上角为原点。要让“鼠标所在位置”始终对应上层图片的同一物理坐标(即实现“窥视”而非“平移”),就必须反向偏移背景图——即 background-position 设为 -(x - r), -(y - r),抵消容器位移。

✅ 进阶优化建议

  • 性能优化:对 mousemove 使用 throttle(如 Lodash 的 throttle 或 requestAnimationFrame 包裹),避免高频重排;
  • 响应式适配:用 vmin 单位定义 .circle 尺寸(如 width: 20vmin; height: 20vmin;),并动态计算 radius;
  • 触屏兼容:补充 touchmove 事件监听,并从 e.touches[0] 读取坐标;
  • 无障碍友好:为 .circle 添加 aria-hidden="true",避免屏幕阅读器误读。

该方案彻底规避了嵌套绝对定位引发的图像“粘连”问题,结构解耦、样式可控、行为精准,适用于产品页视觉引导、图像对比展示、创意悬停交互等多种场景。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
DOM是什么意思
DOM是什么意思

dom的英文全称是documentobjectmodel,表示文件对象模型,是w3c组织推荐的处理可扩展置标语言的标准编程接口;dom是html文档的内存中对象表示,它提供了使用javascript与网页交互的方式。想了解更多的相关内容,可以阅读本专题下面的文章。

3740

2024.08.14

CSS position定位有几种方式
CSS position定位有几种方式

有4种,分别是静态定位、相对定位、绝对定位和固定定位。更多关于CSS position定位有几种方式的内容,可以访问下面的文章。

83

2023.11.23

overflow什么意思
overflow什么意思

overflow是一个用于控制元素溢出内容的属性,当元素的内容超出其指定的尺寸时,overflow属性可以决定如何处理这些溢出的内容。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

1807

2024.08.15

PHP 高并发与性能优化
PHP 高并发与性能优化

本专题聚焦 PHP 在高并发场景下的性能优化与系统调优,内容涵盖 Nginx 与 PHP-FPM 优化、Opcode 缓存、Redis/Memcached 应用、异步任务队列、数据库优化、代码性能分析与瓶颈排查。通过实战案例(如高并发接口优化、缓存系统设计、秒杀活动实现),帮助学习者掌握 构建高性能PHP后端系统的核心能力。

105

2025.10.16

PHP 数据库操作与性能优化
PHP 数据库操作与性能优化

本专题聚焦于PHP在数据库开发中的核心应用,详细讲解PDO与MySQLi的使用方法、预处理语句、事务控制与安全防注入策略。同时深入分析SQL查询优化、索引设计、慢查询排查等性能提升手段。通过实战案例帮助开发者构建高效、安全、可扩展的PHP数据库应用系统。

94

2025.11.13

JavaScript 性能优化与前端调优
JavaScript 性能优化与前端调优

本专题系统讲解 JavaScript 性能优化的核心技术,涵盖页面加载优化、异步编程、内存管理、事件代理、代码分割、懒加载、浏览器缓存机制等。通过多个实际项目示例,帮助开发者掌握 如何通过前端调优提升网站性能,减少加载时间,提高用户体验与页面响应速度。

32

2025.12.30

pixiv网页版官网登录与阅读指南_pixiv官网直达入口与在线访问方法
pixiv网页版官网登录与阅读指南_pixiv官网直达入口与在线访问方法

本专题系统整理pixiv网页版官网入口及登录访问方式,涵盖官网登录页面直达路径、在线阅读入口及快速进入方法说明,帮助用户高效找到pixiv官方网站,实现便捷、安全的网页端浏览与账号登录体验。

76

2026.02.13

微博网页版主页入口与登录指南_官方网页端快速访问方法
微博网页版主页入口与登录指南_官方网页端快速访问方法

本专题系统整理微博网页版官方入口及网页端登录方式,涵盖首页直达地址、账号登录流程与常见访问问题说明,帮助用户快速找到微博官网主页,实现便捷、安全的网页端登录与内容浏览体验。

48

2026.02.13

Flutter跨平台开发与状态管理实战
Flutter跨平台开发与状态管理实战

本专题围绕Flutter框架展开,系统讲解跨平台UI构建原理与状态管理方案。内容涵盖Widget生命周期、路由管理、Provider与Bloc状态管理模式、网络请求封装及性能优化技巧。通过实战项目演示,帮助开发者构建流畅、可维护的跨平台移动应用。

21

2026.02.13

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
Sass 教程
Sass 教程

共14课时 | 0.9万人学习

Bootstrap 5教程
Bootstrap 5教程

共46课时 | 3.3万人学习

CSS教程
CSS教程

共754课时 | 32万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号