0

0

使用HTML、CSS和JavaScript实现动态打字机效果教程

心靈之曲

心靈之曲

发布时间:2025-10-02 11:20:18

|

857人浏览过

|

来源于php中文网

原创

使用HTML、CSS和JavaScript实现动态打字机效果教程

本文详细介绍了如何利用HTML、CSS和JavaScript创建引人入胜的动态打字机效果。通过结构化的HTML元素、CSS动画实现光标闪烁,以及JavaScript控制字符逐个显示和文本循环播放,读者将学会如何为网页添加一个专业且富有交互性的文本展示功能,并掌握其核心实现原理和自定义方法。

实现动态打字机效果

打字机效果是一种常见的网页动态文本展示方式,它能模拟文字逐个字符打出的过程,并常伴随一个闪烁的光标,为用户界面增添趣味性和专业感。本教程将引导您使用htmlcssjavascript,从零开始构建一个功能完善的打字机效果。

1. HTML结构:定义文本容器

首先,我们需要一个HTML元素来承载将要动态显示的文本。为了确保JavaScript能精确地控制这个元素,建议为其分配一个唯一的ID。

在这个例子中,我们使用了一个h1标签,并为其指定了id="typewriter-text"。在实际应用中,您可以根据需要选择任何块级元素(如div、p等)。

2. CSS样式:创建闪烁光标

打字机效果通常包含一个模拟文本输入光标的元素。这个光标可以通过CSS的边框和动画来实现。我们将在JavaScript中动态地将一个元素插入到文本末尾作为光标。

span.typewriter-cursor {
  border-right: .05em solid; /* 光标样式,一个细边框 */
  animation: caret 1s steps(1) infinite; /* 定义闪烁动画 */
}

@keyframes caret {
  50% {
    border-color: transparent; /* 动画50%时边框透明,实现闪烁 */
  }
}

这里,我们定义了一个名为typewriter-cursor的span类,为其设置了右边框作为光标,并通过@keyframes caret动画使其每秒闪烁一次。steps(1)确保了动画是阶梯式的,即瞬间切换,而不是平滑过渡,更符合光标闪烁的视觉效果。

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

Asp开源商城系统YothSHOP
Asp开源商城系统YothSHOP

YothSHOP是优斯科技鼎力打造的一款asp开源商城系统,支持access和Sql server切换,完善的会员订单管理,全站生成静态html文件,SEO优化效果极佳,后台XP模式和普通模式随意切换,极易操作,欢迎使用! Asp开源商城系统YothSHOP功能介绍:1.使用静态页和程序页分离技术,网站可自由开启和关闭,实现全站生成静态页,可动静态切换,方便二次开发和后期维护。2.管理员管理:后台

下载

3. JavaScript逻辑:驱动打字动画

JavaScript是实现打字机效果的核心。它负责控制文本的逐字显示、光标的插入、文本数组的循环以及动画的节奏。

document.addEventListener('DOMContentLoaded', function() {
  // 要循环显示的文本数组
  const dataText = [
    "VISIBILITÀ.",
    "NUOVI INGAGGI.",
    "NUOVI FAN.",
    "PIÙ VISIBILITÀ!",
    "SUCCESSO!"
  ];
  const targetElement = document.getElementById("typewriter-text"); // 获取目标H1元素
  const typingSpeed = 90; // 每个字符打出的间隔时间(毫秒)
  const textDisplayDelay = 2000; // 每个文本显示完毕后的停留时间(毫秒)
  const loopRestartDelay = 20000; // 所有文本循环完毕后重新开始的延迟(毫秒)

  /**
   * 逐字显示文本的函数
   * @param {string} text - 当前要显示的文本
   * @param {number} charIndex - 当前正在显示的字符索引
   * @param {function} fnCallback - 文本显示完毕后要执行的回调函数
   */
  function typeWriter(text, charIndex, fnCallback) {
    // 检查文本是否已全部显示
    if (charIndex < text.length) {
      // 将当前字符添加到目标元素,并插入光标span
      targetElement.innerHTML = text.substring(0, charIndex + 1) + '';

      // 延迟后递归调用自身,显示下一个字符
      setTimeout(function() {
        typeWriter(text, charIndex + 1, fnCallback);
      }, typingSpeed);
    } else if (typeof fnCallback === 'function') {
      // 文本显示完毕,延迟后调用回调函数
      setTimeout(fnCallback, textDisplayDelay);
    }
  }

  /**
   * 启动文本动画循环的函数
   * @param {number} textIndex - dataText数组中当前要显示的文本索引
   */
  function StartTextAnimation(textIndex) {
    // 如果当前文本索引超出数组范围,表示所有文本已显示完毕,等待一段时间后从头开始
    if (typeof dataText[textIndex] === 'undefined') {
      setTimeout(function() {
        StartTextAnimation(0); // 从第一个文本重新开始
      }, loopRestartDelay);
      return; // 提前返回,避免后续执行
    }

    // 检查当前文本是否存在(防止空字符串或undefined)
    if (textIndex < dataText.length) {
      // 启动当前文本的打字机动画
      typeWriter(dataText[textIndex], 0, function() {
        // 当前文本动画完成后,启动下一个文本的动画
        StartTextAnimation(textIndex + 1);
      });
    }
  }

  // 页面加载完成后,启动第一个文本的动画
  StartTextAnimation(0);
});

代码解析与注意事项:

  1. DOMContentLoaded事件监听器: 确保所有HTML内容加载完毕后再执行JavaScript代码,避免因元素未加载而导致的错误。

  2. dataText数组: 存储所有需要循环显示的文本字符串。您可以根据需要修改或扩展这个数组。

  3. targetElement: 使用document.getElementById("typewriter-text")精确地获取到要显示文本的HTML元素。这是解决原始问题中“计算所有h1”的关键,通过ID定位可以避免影响页面上其他同类型元素。

  4. typeWriter(text, charIndex, fnCallback)函数:

    • 这是一个递归函数,负责逐个字符地将text显示到targetElement中。
    • text.substring(0, charIndex + 1)用于截取当前已打出的字符。
    • :在每次更新文本时,我们都会在已打出的文本后面添加这个光标span。aria-hidden="true"属性告知辅助技术(如屏幕阅读器)忽略此元素,因为它纯粹是视觉效果,不提供语义信息。
    • setTimeout:控制每个字符之间的时间间隔(typingSpeed),模拟打字机的速度。
    • fnCallback:当整个文本显示完毕后,会调用这个回调函数,通常用于触发下一个文本的显示。
  5. StartTextAnimation(textIndex)函数:

    • 负责管理dataText数组中文本的循环显示。
    • 它会检查dataText[textIndex]是否存在。
    • 如果当前textIndex超出了dataText数组的范围,意味着所有文本都已显示一遍,它会等待loopRestartDelay时间后,通过StartTextAnimation(0)重新开始整个循环。
    • 如果当前文本存在,它会调用typeWriter函数来显示该文本,并在typeWriter完成后,递归调用StartTextAnimation(textIndex + 1)来处理下一个文本。

关键自定义点:

  • 文本内容: 修改dataText数组以改变显示的文本内容。
  • 打字速度: 调整typingSpeed变量(毫秒)来加快或减慢字符显示速度。
  • 文本停留时间: 调整textDisplayDelay变量(毫秒)来控制每个文本显示完毕后等待下一个文本开始的时间。
  • 循环重启延迟: 调整loopRestartDelay变量(毫秒)来控制所有文本播放完毕后,重新开始循环的等待时间。
  • 光标样式: 修改CSS中.typewriter-cursor的样式,例如改变颜色、大小或动画速度。
  • 目标元素: 如果您想在其他元素上实现此效果,只需修改HTML中的id和JavaScript中的targetElement变量。

通过上述HTML、CSS和JavaScript的结合,您便能轻松地在网页上实现一个动态且富有吸引力的打字机效果。这种技术不仅提升了用户体验,也为信息展示提供了更具创意的方式。

相关文章

HTML速学教程(入门课程)
HTML速学教程(入门课程)

HTML怎么学习?HTML怎么入门?HTML在哪学?HTML怎么学才快?不用担心,这里为大家提供了HTML速学教程(入门课程),有需要的小伙伴保存下载就能学习啦!

下载

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

相关专题

更多
js获取数组长度的方法
js获取数组长度的方法

在js中,可以利用array对象的length属性来获取数组长度,该属性可设置或返回数组中元素的数目,只需要使用“array.length”语句即可返回表示数组对象的元素个数的数值,也就是长度值。php中文网还提供JavaScript数组的相关下载、相关课程等内容,供大家免费下载使用。

544

2023.06.20

js刷新当前页面
js刷新当前页面

js刷新当前页面的方法:1、reload方法,该方法强迫浏览器刷新当前页面,语法为“location.reload([bForceGet]) ”;2、replace方法,该方法通过指定URL替换当前缓存在历史里(客户端)的项目,因此当使用replace方法之后,不能通过“前进”和“后退”来访问已经被替换的URL,语法为“location.replace(URL) ”。php中文网为大家带来了js刷新当前页面的相关知识、以及相关文章等内容

372

2023.07.04

js四舍五入
js四舍五入

js四舍五入的方法:1、tofixed方法,可把 Number 四舍五入为指定小数位数的数字;2、round() 方法,可把一个数字舍入为最接近的整数。php中文网为大家带来了js四舍五入的相关知识、以及相关文章等内容

727

2023.07.04

js删除节点的方法
js删除节点的方法

js删除节点的方法有:1、removeChild()方法,用于从父节点中移除指定的子节点,它需要两个参数,第一个参数是要删除的子节点,第二个参数是父节点;2、parentNode.removeChild()方法,可以直接通过父节点调用来删除子节点;3、remove()方法,可以直接删除节点,而无需指定父节点;4、innerHTML属性,用于删除节点的内容。

470

2023.09.01

JavaScript转义字符
JavaScript转义字符

JavaScript中的转义字符是反斜杠和引号,可以在字符串中表示特殊字符或改变字符的含义。本专题为大家提供转义字符相关的文章、下载、课程内容,供大家免费下载体验。

393

2023.09.04

js生成随机数的方法
js生成随机数的方法

js生成随机数的方法有:1、使用random函数生成0-1之间的随机数;2、使用random函数和特定范围来生成随机整数;3、使用random函数和round函数生成0-99之间的随机整数;4、使用random函数和其他函数生成更复杂的随机数;5、使用random函数和其他函数生成范围内的随机小数;6、使用random函数和其他函数生成范围内的随机整数或小数。

990

2023.09.04

如何启用JavaScript
如何启用JavaScript

JavaScript启用方法有内联脚本、内部脚本、外部脚本和异步加载。详细介绍:1、内联脚本是将JavaScript代码直接嵌入到HTML标签中;2、内部脚本是将JavaScript代码放置在HTML文件的`<script>`标签中;3、外部脚本是将JavaScript代码放置在一个独立的文件;4、外部脚本是将JavaScript代码放置在一个独立的文件。

655

2023.09.12

Js中Symbol类详解
Js中Symbol类详解

javascript中的Symbol数据类型是一种基本数据类型,用于表示独一无二的值。Symbol的特点:1、独一无二,每个Symbol值都是唯一的,不会与其他任何值相等;2、不可变性,Symbol值一旦创建,就不能修改或者重新赋值;3、隐藏性,Symbol值不会被隐式转换为其他类型;4、无法枚举,Symbol值作为对象的属性名时,默认是不可枚举的。

544

2023.09.20

php源码安装教程大全
php源码安装教程大全

本专题整合了php源码安装教程,阅读专题下面的文章了解更多详细内容。

74

2025.12.31

热门下载

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

精品课程

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

共14课时 | 0.7万人学习

Bootstrap 5教程
Bootstrap 5教程

共46课时 | 2.7万人学习

CSS教程
CSS教程

共754课时 | 17.5万人学习

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

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