vue2实现多段打字机效果

实现效果

多段打字,每段之间延迟一点时间,末尾有光标

页面结构

所有的“打字”的效果都在typedText里面展现,打印完了就把这一段加入displayedParagraphs中,同时清空typedText。

displayedParagraphs就是正常v-for渲染

画板

数据结构

data() {return {typingSpeed: 100, // 打字速度paragraphGap: 1000, // 每段间隔的时间(ms)currentIndex: 0, // 当前段落字符索引currentParagraph: 0, // 当前段落索引typedText: "", // 当前正在打字的内容displayedParagraphs: [], // 已完成显示的段落typingComplete: false, // 是否完成}
},

方法解析

typeWriterEffect的作用是打印一段话

组件示例

<template><div><div class="section1"><div class="section1-word"><!-- 动态渲染每个段落 --><div v-for="(paragraph, index) in displayedParagraphs" :key="index" class="paragraph"><span>{{ paragraph }}</span></div><!-- 当前正在打字的段落 --><div v-if="!typingComplete" class="paragraph"><span>{{ typedText }}</span><span class="cursor"></span> <!-- 光标 --></div></div></div></div>
</template><script>import {mapState} from "vuex";import axios from 'axios';import {nextTick} from "vue";export default {name: "stepDetail",data() {return {step: 0, // 步数// 剩下的由gpt生成的段落gptFullText: [],typingSpeed: 100, // 打字速度paragraphGap: 1000, // 每段间隔的时间(ms)currentIndex: 0, // 当前段落字符索引currentParagraph: 0, // 当前段落索引typedText: "", // 当前正在打字的内容displayedParagraphs: [], // 已完成显示的段落typingComplete: false, // 是否完成}},computed: {...mapState(['currentUserId', 'userData']),fullText() {// 所有段落的内容return [`从上次统计开始,你步行了${this.step}步,相当于减少了约${this.step / 1000 * 200}g的碳排放。这看似微小的行动,却为地球注入了源源不断的生命之力。`,...this.gptFullText]}},methods: {// 打字效果/*** 模拟打字机效果,逐个字符地显示文本,并在段落之间添加延迟。** @method typeWriterEffect* @returns {void} - 无返回值。*/typeWriterEffect() {const interval = setInterval(() => {const currentText = this.fullText[this.currentParagraph];if (this.currentIndex < currentText.length) {this.typedText += currentText.charAt(this.currentIndex);this.currentIndex++;} else {clearInterval(interval);this.displayedParagraphs.push(this.typedText);this.typedText = "";this.currentIndex = 0;this.currentParagraph++;if (this.currentParagraph < this.fullText.length) {// 延迟显示下一段setTimeout(this.typeWriterEffect, this.paragraphGap);} else {this.typingComplete = true;}}}, this.typingSpeed);},async getGptText() {this.gptFullText = gpt返回的文本内容;}},created() {this.step = this.userData[this.currentUserId].step;},mounted() {this.$nextTick(() => {this.getGptText();this.typeWriterEffect();});}
}
</script><style scoped lang="scss">
.section1 {width: 90%;height: calc(100vh - 200px);margin: auto;padding-top: 20px;overflow: auto;.section1-word {color: white;font-size: 30px;position: relative;display: flex;flex-direction: column; /* 垂直排列段落 */gap: 20px; /* 段落间距 */font-family: 'SanJinSong-Xi', serif;}.cursor {display: inline-block;width: 2px;height: 1em;background-color: white;margin-left: 5px;animation: blink 1s step-start infinite;}@keyframes blink {50% {background-color: transparent;}}
}
</style>

在这里插入图片描述

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.rhkb.cn/news/489827.html

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

力扣打卡14:多数元素

链接&#xff1a;169. 多数元素 - 力扣&#xff08;LeetCode&#xff09; 这道题正常很简单&#xff0c;但是如果想要完成进阶做法有点困难。我使用了O(n/2)左右的空间&#xff0c;使用了哈希映映射。 看了题解&#xff0c;有一种解法叫摩尔投票&#xff0c;可以解决这种问题…

SQL server学习03-创建和管理数据表

目录 一&#xff0c;SQL server的数据类型 1&#xff0c;基本数据类型 2&#xff0c;自定义数据类型 二&#xff0c;使用T-SQL创建表 1&#xff0c;数据完整性的分类 2&#xff0c;约束的类型 3&#xff0c;创建表时创建约束 4&#xff0c;任务 5&#xff0c;由任务编写…

【网络攻击与防范】常见服务的配置方法

一、DHCP 服务的安装与配置 1、安装 2、验证安装 3、启动、停止和重新启动 4、配置作用域 Scope 检验配置&#xff1a;netsh 5、DHCP服务器选项 6、利用 kali 客户端来进行验证 将 kali 的网卡也设置在 VMnet2 中&#xff1a; 二、DNS服务的安装与配置 1、安装 2、验证安装 …

移动端h5自适应rem适配最佳方案

网页开发中&#xff0c;我们常用的单位有如下几个&#xff1a; px&#xff1a;像素固定&#xff0c;无法适配各分辨率的移动设备em: 该单位受父容器影响&#xff0c;大小为父元素的倍数rem: 因为html根元素大小为16px&#xff0c;所以默认 1rem 16px&#xff0c;rem只受根元素…

ubuntu20.04复现 Leg-KILO

这里写目录标题 opencv版本问题下载3.2.0源代码进入解压后的目录创建构建目录运行 CMake 配置 配置时指定一个独立的安装目录&#xff0c;例如 /opt/opencv-3.2&#xff1a;出错&#xff1a; 使用多线程编译错误1&#xff1a; stdlib.h: 没有那个文件或目录错误2&#xff1a;er…

Python爬虫之Selenium的应用

【1】Selenium基础介绍 1.什么是selenium&#xff1f; &#xff08;1&#xff09;Selenium是一个用于Web应用程序测试的工具。 &#xff08;2&#xff09;Selenium 测试直接运行在浏览器中&#xff0c;就像真正的用户在操作一样。 &#xff08;3&#xff09;支持通过各种driv…

回归预测 | MATLAB实现BiGRU(双向门控循环单元)多输入单输出

回归预测 | MATLAB实现BiGRU(双向门控循环单元)多输入单输出 文章目录 回归预测 | MATLAB实现BiGRU(双向门控循环单元)多输入单输出预测效果基本介绍程序设计参考资料致谢预测效果 基本介绍 BiGRU(双向门控循环单元)多输入单输出模型是一种结合了双向门控循环单元(BiGRU)的…

React的状态管理库-Redux

核心思想&#xff1a;单一数据源、状态是只读的、以及使用纯函数更新状态。 组成部分 Store&#xff08;存储&#xff09; 应用的唯一状态容器&#xff0c;存储整个应用的状态树,使用 createStore() 创建。 getState()&#xff1a;获取当前状态。dispatch(action)&#xff…

.NET平台使用C#设置Excel单元格数值格式

设置Excel单元格的数字格式是创建、修改和格式化Excel文档的关键步骤之一&#xff0c;它不仅确保了数据的正确表示&#xff0c;还能够增强数据的可读性和专业性。正确的数字格式可以帮助用户更直观地理解数值的意义&#xff0c;减少误解&#xff0c;并且对于自动化报告生成、财…

【Maven】生命周期和插件详解

Maven生命周期 Maven 将项目的生命周期抽象成了 3 套生命周期&#xff0c;每套生命周期又包含多个阶段&#xff08;phase&#xff09;。每套中具体包含哪些阶段是 Maven 已经约定好的&#xff0c;但是每个阶段具体需要做什么&#xff0c;是用户可以自己指定的。 Maven 中定义…

数据保护策略:如何保障重要信息的安全

一、什么是数据安全&#xff1f; 数据安全是保护数字信息免遭盗窃、未经授权的访问和恶意修改的过程。这是一个持续的过程&#xff0c;负责监督信息的收集、存储和传输。 机密性&#xff1a;保护数据免遭未授权方访问。 完整性&#xff1a;保护数据免遭未经授权的修改、损坏…

Linux:进程(环境变量、程序地址空间)

目录 冯诺依曼体系结构 操作系统 设计操作系统的目的 操作系统的管理 进程 PCB fork 进程状态 进程状态查看 僵尸进程 孤儿进程 进程优先级 查看、修改进程优先级命令 竞争、独立、并行、并发 进程切换 活动队列和运行队列 活动队列 过期队列 active指针…

ansible自动化运维(一)简介及清单,模块

相关文章ansible自动化运维&#xff08;二&#xff09;playbook模式详解-CSDN博客ansible自动化运维&#xff08;三&#xff09;jinja2模板&&roles角色管理-CSDN博客ansible自动化运维&#xff08;四&#xff09;运维实战-CSDN博客 ansible自动化运维工具 1.什么是自…

DuckDB快速入门教程

DuckDB是一个用c编写的进程内OLAP DBMS&#xff0c;太复杂了。我们从简单的开始&#xff0c;好吗&#xff1f;DuckDB是用于分析的SQLite。它没有依赖关系&#xff0c;非常容易设置&#xff0c;并且经过优化可以对数据执行查询。本文将介绍什么是DuckDB&#xff0c;如何使用它&a…

【橘子容器】如何构建一个docker镜像

你肯定打过docker镜像是吧&#xff0c;作为一个开发这很正常&#xff0c;那么你用的什么打包方式呢&#xff0c;这里我们来梳理几种常用的docker镜像构建方式。 ps&#xff1a;这里不是太讲原理&#xff0c;更多的是一种科普和操作。因为讲原理的东西网上已经够多了。 一、Dock…

操作系统(8)死锁

一、概念 死锁是指在一个进程集合中的每个进程都在等待只能由该集合中的其他进程才能引起的事件&#xff0c;而无限期地僵持下去的局面。在多任务环境中&#xff0c;由于资源分配不当&#xff0c;导致两个或多个进程在等待对方释放资源时陷入无限等待的状态&#xff0c;这就是死…

el-table行合并及合并后序号处理

效果图 <el-tableclass"ncky-detail-table"v-loading"tableLoading"border:data"tableDataVo":span-method"objectSpanMethod"row-key"uniqueFlag":row-class-name"tablerowclassname"><el-table-column…

【Python】使用Selenium的find_element模块获取网页上的大段文字和表格的方法(建议收藏!)

发现了一个使用Selenium的find_element模块&#xff0c;快速获取文字和表格的方法&#xff0c;很实在&#xff0c;以后爬网的时候&#xff0c;就不用beautifulSoup 和 pandas的read_html 混起来用了&#xff01; 文字部分&#xff1a;实现网络节点下&#xff0c;某个节点下的其…

24秋:模式识别:答题第一波除解析

判断题&#xff1a; T 模式识别中的人脸识别问题是根据已知数据类别预测未知数据类别的问题。F 人脸图像在计算机中是以矩阵的方式存储的。F 训练集和测试集有交集。T 算法&#xff08;模型&#xff09;是以样本所包含的信息为基础&#xff0c;对总体的某些特征进行判断、预测…

【蓝桥杯每日一题】推导部分和——带权并查集

推导部分和 2024-12-11 蓝桥杯每日一题 推导部分和 带权并查集 题目大意 对于一个长度为 ( N ) 的整数数列 ( A 1 , A 2 , ⋯ , A N A_1, A_2, \cdots, A_N A1​,A2​,⋯,AN​ )&#xff0c;小蓝想知道下标 ( l ) 到 ( r ) 的部分和 ∑ i l r A i A l A l 1 ⋯ A r \su…