0

0

为每个动态生成的图片元素设置独立的 CSS 动画延迟

碧海醫心

碧海醫心

发布时间:2026-03-11 16:38:21

|

156人浏览过

|

来源于php中文网

原创

本文讲解如何在 JavaScript 动态创建 元素时,立即为其分配唯一的 animation-delay 值,避免后续遍历 DOM,确保每个字符图片实现错峰“浮动”动画效果。

本文讲解如何在 javascript 动态创建 `为每个动态生成的图片元素设置独立的 CSS 动画延迟` 元素时,立即为其分配唯一的 `animation-delay` 值,避免后续遍历 dom,确保每个字符图片实现错峰“浮动”动画效果。

在构建基于文本输入的字符图像化展示(如 ASCII 风格字体渲染)时,一个常见需求是让每个生成的 为每个动态生成的图片元素设置独立的 CSS 动画延迟 元素拥有独立、随机的动画起始时间,从而营造自然错落的视觉动效(例如“上下浮动”)。若采用先批量创建元素、再统一 querySelectorAll('img.bobbing-photo').forEach(...) 的方式,不仅冗余,还容易因 DOM 更新时机或类名遗漏导致部分图片未生效——正如问题中所见:即使调用了 image.classList.add("bobbing-photo"),但延迟样式未同步应用,动画便无法按预期错开。

核心解法:在创建元素的瞬间,即刻设置动画属性,而非依赖事后遍历。这既提升性能,又保证逻辑原子性与可靠性。

以下是一个优化后的 generateImages() 实现,支持任意文本输入(含空格、换行),并为每个有效字符图片注入随机动画延迟:

function generateImages(text) {
  const imageOutput = document.getElementById('imageOutput');
  imageOutput.innerHTML = ''; // 清空旧内容

  for (let i = 0; i < text.length; i++) {
    const char = text[i].toUpperCase();
    let element;

    if (char === '\n') {
      element = document.createElement('br');
    } else if (char === ' ') {
      element = document.createElement('img');
      element.src = 'FONT/SPACE.png';
    } else {
      element = document.createElement('img');
      element.src = `FONT/${char}.png`;
      element.classList.add('bobbing-photo');

      // ✅ 关键:创建时立即设置随机延迟(单位:秒)
      const randomDelay = Math.random() * 2; // 0–2 秒范围
      element.style.animationDelay = `${randomDelay}s`;

      // (可选)增强视觉层次:叠加随机垂直偏移
      element.style.top = `${(Math.random() - 0.5) * 1.2}em`;
    }

    imageOutput.append(element);
  }
}

// 实时响应输入
document.getElementById('userInput').addEventListener('input', (e) => {
  generateImages(e.target.value);
});

配套的 CSS 动画定义需确保 .bobbing-photo 具备相对定位与循环动画能力:

星月写作
星月写作

专为网络小说、 剧本创作者打造的AI增效工具

下载

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

.bobbing-photo {
  position: relative;
  display: inline-block;
  vertical-align: middle;
  animation: bobbing 0.3s infinite ease-in-out;
}

@keyframes bobbing {
  0% { transform: translateY(0); }
  50% { transform: translateY(-0.8em); }
  100% { transform: translateY(0); }
}

⚠️ 注意事项

  • animationDelay 接受字符串值(如 '1.42s'),务必拼接单位,否则无效;
  • 若使用负延迟(如 -randomDelay + "s"),需确保动画已定义 forwards 或 both 填充模式,否则可能跳过初始帧;本例推荐正向延迟 + infinite 循环,语义更清晰;
  • SVG 替代方案(如答案中 generateTextSvg)适合无图资源场景,但注意 data:image/svg+xml 需 encodeURIComponent 编码,且复杂 SVG 可能影响渲染性能;
  • 避免在循环中频繁操作 innerHTML(已修正为 append),减少重排重绘。

通过将动画配置内聚于元素创建流程,代码更健壮、可维护性更高,也完全规避了“类名已加但样式未生效”的典型陷阱。这是动态 UI 中处理批量动画的推荐实践。

本站声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

热门AI工具

更多
DeepSeek
DeepSeek

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

豆包大模型
豆包大模型

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

通义千问
通义千问

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

腾讯元宝
腾讯元宝

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

文心一言
文心一言

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

讯飞写作
讯飞写作

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

即梦AI
即梦AI

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

ChatGPT
ChatGPT

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

相关专题

更多
php中foreach用法
php中foreach用法

本专题整合了php中foreach用法的相关介绍,阅读专题下面的文章了解更多详细教程。

266

2025.12.04

pdf怎么转换成xml格式
pdf怎么转换成xml格式

将 pdf 转换为 xml 的方法:1. 使用在线转换器;2. 使用桌面软件(如 adobe acrobat、itext);3. 使用命令行工具(如 pdftoxml)。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

1946

2024.04.01

xml怎么变成word
xml怎么变成word

步骤:1. 导入 xml 文件;2. 选择 xml 结构;3. 映射 xml 元素到 word 元素;4. 生成 word 文档。提示:确保 xml 文件结构良好,并预览 word 文档以验证转换是否成功。想了解更多xml的相关内容,可以阅读本专题下面的文章。

2119

2024.08.01

xml是什么格式的文件
xml是什么格式的文件

xml是一种纯文本格式的文件。xml指的是可扩展标记语言,标准通用标记语言的子集,是一种用于标记电子文件使其具有结构性的标记语言。想了解更多相关的内容,可阅读本专题下面的相关文章。

1168

2024.11.28

js 字符串转数组
js 字符串转数组

js字符串转数组的方法:1、使用“split()”方法;2、使用“Array.from()”方法;3、使用for循环遍历;4、使用“Array.split()”方法。本专题为大家提供js字符串转数组的相关的文章、下载、课程内容,供大家免费下载体验。

760

2023.08.03

js截取字符串的方法
js截取字符串的方法

js截取字符串的方法有substring()方法、substr()方法、slice()方法、split()方法和slice()方法。本专题为大家提供字符串相关的文章、下载、课程内容,供大家免费下载体验。

221

2023.09.04

java基础知识汇总
java基础知识汇总

java基础知识有Java的历史和特点、Java的开发环境、Java的基本数据类型、变量和常量、运算符和表达式、控制语句、数组和字符串等等知识点。想要知道更多关于java基础知识的朋友,请阅读本专题下面的的有关文章,欢迎大家来php中文网学习。

1566

2023.10.24

字符串介绍
字符串介绍

字符串是一种数据类型,它可以是任何文本,包括字母、数字、符号等。字符串可以由不同的字符组成,例如空格、标点符号、数字等。在编程中,字符串通常用引号括起来,如单引号、双引号或反引号。想了解更多字符串的相关内容,可以阅读本专题下面的文章。

649

2023.11.24

C# ASP.NET Core微服务架构与API网关实践
C# ASP.NET Core微服务架构与API网关实践

本专题围绕 C# 在现代后端架构中的微服务实践展开,系统讲解基于 ASP.NET Core 构建可扩展服务体系的核心方法。内容涵盖服务拆分策略、RESTful API 设计、服务间通信、API 网关统一入口管理以及服务治理机制。通过真实项目案例,帮助开发者掌握构建高可用微服务系统的关键技术,提高系统的可扩展性与维护效率。

3

2026.03.11

热门下载

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

精品课程

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

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