0

0

CSS动画中的光影追踪效果_模拟手电筒扫过文字的动效

P粉602998670

P粉602998670

发布时间:2026-02-12 15:51:10

|

740人浏览过

|

来源于php中文网

原创

手电筒光斑效果需用 radial-gradient 配合 background-clip: text + color: transparent 实现文字镂空,光斑坐标须动态计算相对位置并节流更新,避免 mask-image 等兼容性差方案,加 will-change: transform 提升动画流畅度。

css动画中的光影追踪效果_模拟手电筒扫过文字的动效

怎么用 radial-gradient 做手电筒光斑

核心是把文字设为透明或镂空,让底层的渐变光斑“透”出来。不能靠阴影或滤镜硬叠,否则边缘发虚、动起来卡顿。

  • background-clip: text + color: transparent 是最稳的文字镂空方案,兼容 Chrome/Firefox/Safari(≥15.4)
  • 光斑必须用 radial-gradient(circle at Xpx Ypx, white, transparent 70%)at 后面的坐标要动态更新,别写死成 50% 50%
  • 别用 box-shadow 模拟光晕——它无法随鼠标平滑位移,且在 transform 动画中会触发重绘,掉帧明显

鼠标移动时如何实时更新光斑位置

监听 mousemove 获取坐标后,得转换成相对于文字容器的局部坐标,否则光斑会跑偏。

  • element.getBoundingClientRect() 拿容器位置,再减去 event.clientX/clientY,算出相对偏移
  • 直接设 style.backgroundPosition 最轻量;别用 CSS Custom Property 配合 @keyframes,那玩意儿没法实时响应鼠标
  • throttle(比如 60ms 一次),不然高频触发会让 requestAnimationFrame 都救不了——尤其在低配笔记本上,光斑会拖影

为什么 mask-image 方案在 Safari 上容易失效

Safari 对 mask-image + radial-gradient 的组合支持不稳定,特别是配合 transform 或父容器有 overflow: hidden 时,光斑直接消失。

Veed AI Voice Generator
Veed AI Voice Generator

Veed推出的AI语音生成器

下载
  • 错误现象:mask-image: radial-gradient(...) 在 Safari 中完全不生效,但 Chrome 正常
  • 根本原因:Safari 要求 mask 的尺寸必须显式声明,得补上 -webkit-mask-size: 200% 200%-webkit-mask-position: center
  • 更省事的解法:放弃 mask,回到 background-clip: text + 渐变背景,兼容性好,代码少一半

动画卡顿或光斑闪烁的三个隐藏原因

不是性能差,而是 CSS 层叠和重绘逻辑被误触了。

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

  • 文字父容器没设 will-change: transform,导致每次 backgroundPosition 更新都触发 layout —— 加上它,光斑滑动立刻顺滑
  • 用了 filter: blur() 给光斑加柔边?小心:blur 会让整个图层进 GPU,内存暴涨,移动端直接卡死;改用多层渐变叠加模拟柔边更安全
  • 如果文字是 position: absolute,且父容器 transform: translateZ(0),某些旧版 Chrome 会丢弃 background-clip 效果——去掉父容器的 transform,或换用 contain: layout paint
光斑坐标的计算精度、浏览器对 background-clip: text 的渲染节奏、还有那一行被忽略的 will-change,才是动效是否“像手电筒”的分水岭。

热门AI工具

更多
DeepSeek
DeepSeek

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

豆包大模型
豆包大模型

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

通义千问
通义千问

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

腾讯元宝
腾讯元宝

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

文心一言
文心一言

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

讯飞写作
讯飞写作

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

即梦AI
即梦AI

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

ChatGPT
ChatGPT

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

相关专题

更多
chrome什么意思
chrome什么意思

chrome是浏览器的意思,由Google开发的网络浏览器,它在2008年首次发布,并迅速成为全球最受欢迎的浏览器之一。本专题为大家提供chrome相关的文章、下载、课程内容,供大家免费下载体验。

938

2023.08.11

chrome无法加载插件怎么办
chrome无法加载插件怎么办

chrome无法加载插件可以通过检查插件是否已正确安装、禁用和启用插件、清除插件缓存、更新浏览器和插件、检查网络连接和尝试在隐身模式下加载插件方法解决。更多关于chrome相关问题,详情请看本专题下面的文章。php中文网欢迎大家前来学习。

777

2023.11.06

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

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

83

2023.11.23

overflow什么意思
overflow什么意思

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

1803

2024.08.15

c语言 数据类型
c语言 数据类型

本专题整合了c语言数据类型相关内容,阅读专题下面的文章了解更多详细内容。

24

2026.02.12

雨课堂网页版登录入口与使用指南_官方在线教学平台访问方法
雨课堂网页版登录入口与使用指南_官方在线教学平台访问方法

本专题系统整理雨课堂网页版官方入口及在线登录方式,涵盖账号登录流程、官方直连入口及平台访问方法说明,帮助师生用户快速进入雨课堂在线教学平台,实现便捷、高效的课程学习与教学管理体验。

9

2026.02.12

豆包AI网页版入口与智能创作指南_官方在线写作与图片生成使用方法
豆包AI网页版入口与智能创作指南_官方在线写作与图片生成使用方法

本专题汇总豆包AI官方网页版入口及在线使用方式,涵盖智能写作工具、图片生成体验入口和官网登录方法,帮助用户快速直达豆包AI平台,高效完成文本创作与AI生图任务,实现便捷智能创作体验。

98

2026.02.12

PostgreSQL性能优化与索引调优实战
PostgreSQL性能优化与索引调优实战

本专题面向后端开发与数据库工程师,深入讲解 PostgreSQL 查询优化原理与索引机制。内容包括执行计划分析、常见索引类型对比、慢查询优化策略、事务隔离级别以及高并发场景下的性能调优技巧。通过实战案例解析,帮助开发者提升数据库响应速度与系统稳定性。

11

2026.02.12

Next.js全栈开发与SSR服务端渲染实战
Next.js全栈开发与SSR服务端渲染实战

本专题系统讲解 Next.js 框架在现代全栈开发中的应用,重点解析 SSR、SSG 与 ISR 渲染模式的原理与差异。内容涵盖路由系统、API Routes、数据获取策略、性能优化以及部署实践。通过完整项目示例,帮助开发者掌握高性能 SEO 友好的 React 全栈开发方案。

11

2026.02.12

热门下载

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

精品课程

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

共14课时 | 0.9万人学习

Bootstrap 5教程
Bootstrap 5教程

共46课时 | 3.3万人学习

CSS教程
CSS教程

共754课时 | 30.9万人学习

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

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