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 时,光斑直接消失。

lavender.ai
lavender.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相关的文章、下载、课程内容,供大家免费下载体验。

932

2023.08.11

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

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

776

2023.11.06

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

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

83

2023.11.23

overflow什么意思
overflow什么意思

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

1800

2024.08.15

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

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

0

2026.02.12

Kotlin协程编程与Spring Boot集成实践
Kotlin协程编程与Spring Boot集成实践

本专题围绕 Kotlin 协程机制展开,深入讲解挂起函数、协程作用域、结构化并发与异常处理机制,并结合 Spring Boot 展示协程在后端开发中的实际应用。内容涵盖异步接口设计、数据库调用优化、线程资源管理以及性能调优策略,帮助开发者构建更加简洁高效的 Kotlin 后端服务架构。

3

2026.02.12

2026春节习俗大全
2026春节习俗大全

本专题整合了2026春节习俗大全,阅读专题下面的文章了解更多详细内容。

192

2026.02.11

Yandex网页版官方入口使用指南_国际版与俄罗斯版访问方法解析
Yandex网页版官方入口使用指南_国际版与俄罗斯版访问方法解析

本专题全面整理了Yandex搜索引擎的官方入口信息,涵盖国际版与俄罗斯版官网访问方式、网页版直达入口及免登录使用说明,帮助用户快速、安全地进入Yandex官网,高效使用其搜索与相关服务。

599

2026.02.11

虫虫漫画网页版入口与免费阅读指南_正版漫画全集在线查看方法
虫虫漫画网页版入口与免费阅读指南_正版漫画全集在线查看方法

本专题系统整理了虫虫漫画官网及网页版最新入口,涵盖免登录观看、正版漫画全集在线阅读方式,并汇总稳定可用的访问渠道,帮助用户快速找到虫虫漫画官方页面,轻松在线阅读各类热门漫画内容。

91

2026.02.11

热门下载

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

精品课程

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

共14课时 | 0.9万人学习

Bootstrap 5教程
Bootstrap 5教程

共46课时 | 3.3万人学习

CSS教程
CSS教程

共754课时 | 30.5万人学习

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

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