「CSS畅想」自动打字效果,默写首诗来读读

简介: 用技术实现梦想,用梦想打开前端技术之门。今天写了一个自动打字效果。

前言

想到之前做过打字功能,虽说不是一个复杂的功能,但是确实是一个好玩的效果,新平台配上好玩的功能,想想还有那么点妙呢。

不过之前的功能是打一行字,文字内容由一两句话交替出现。突然想起了诗词大会上介绍某首诗的时候,用的逐字逐句出现的展现方式。打字功能也实现这种方式,这个效果有点好玩。

setTimeout才是“真绝色”

每一个我们能看到的展示或者动效,可能都有很多实现方式,这是也是技术魅力的所在,可以让人不断探索新的实现方式。

但是,说到自动打字,我首先想到的还是定时功能。100毫秒的间隔出现1个字,进而呈现出来逐字逐句的动态效果。

vartimer=setTimeout(functiontyping() {
// 逐字获取}, 100);

何不来首《侠客行》

侠客行是我很喜欢的唐朝诗仙李白的一首诗。


功能实现

html

  • 页面展示很简介,分为两大块,标题和诗文内容;
  • 诗文内容部分分为三个块,诗文的标题、诗文的作者、诗文的内容;每个部分添加唯一的id值。
<divclass="center"><divclass="title">自动打字默写《侠客行》</div><divclass="content"><divid="dlsthTitle"></div><divid="dlsthAuthor"></div><divid="dlsth"></div></div></div>

css

  • 诗文内容的外边框样式设置,添加了box-shadow属性,边框添加阴影效果是比较常见的方式,增添了视觉上的靓丽效果;
  • 诗文内容的换行样式设置,这次是通过设置容器内侧的填充距离,保持诗文的换行效果的展示。
* {
padding: 0;
margin: 0;
      }
      .center {
width: 600px;
height: auto;
margin: 30pxauto;
      }
      .title {
line-height: 1.2;
font-size: 20px;
color: #4860d6;font-weight: 300;
margin-bottom: 20px;
      }
      .content {
width: 180px;
height: 310px;
border: 1pxsolid#4860d6;color: #333;padding: 20px50px;
box-shadow: 3px5px5px#4860d6;border-radius: 5px;
font-weight: 300;
text-align: center;
      }
#dlsthTitle {font-size: 18px;
line-height: 1.5;
margin-bottom: 10px;
font-weight: 300;
      }
#dlsthAuthor {font-size: 13px;
line-height: 1.5;
margin-bottom: 10px;
font-weight: 300;
      }
#dlsth {font-size: 14px;
      }

js

  • 诗文内容,定义为数组对象,数组主要包括诗文的标题、作者、内容三个元素;
  • 使用setTimeout函数设置定时任务,进行数组对象的循环,展示每个部分的每个文字;
  • 数组每个元素完成展示之后,使用clearTimeout清除定时,释放定时器。
vardlsthList= [
      {
index: 0,
flag: true,
id: document.getElementById('dlsthTitle'),
content: '《侠客行》',
      },
      {
index: 0,
flag: false,
id: document.getElementById('dlsthAuthor'),
content: '唐·李白',
      },
      {
index: 0,
flag: false,
id: document.getElementById('dlsth'),
content: '赵客缦胡缨,吴钩霜雪明。银鞍照白马,飒沓如流星。十步杀一人,千里不留行。事了拂衣去,深藏身与名。闲过信陵饮,脱剑膝前横。将炙啖朱亥,持觞劝侯嬴。三杯吐然诺,五岳倒为轻。眼花耳热后,意气素霓生。救赵挥金槌,邯郸先震惊。千秋二壮士,烜赫大梁城。纵死侠骨香,不惭世上英。谁能书阁下,白首太玄经。',
      },
    ];
varlen=dlsthList.length;
functiontyping() {
dlsthList.map(function (item, index) {
if (item.flag) {
if (item.index<=item.content.length) {
item['id'].innerHTML=item.content.substring(0, item.index++) +'|';
item.timer=setTimeout(typing, 100);
          } else {
item['id'].innerHTML=item.content;
clearTimeout(item.timer);
if (index!==len-1) {
dlsthList[index+1].flag=true;
            }
item.flag=false;
          }
        }
      });
    }
typing();

效果展示


在线预览平台查看动画效果和完整代码。


总结

虽然是基础版的前端打字效果。

但是偶尔来点这种小效果,为生活增添的小乐趣,甚好。

目录
相关文章
|
3月前
|
JavaScript 前端开发
vue 模拟随机变速的动态打字特效【支持多行文本】(含css实现闪烁光标,js动态改变setInterval定时器的时间间隔)
vue 模拟随机变速的动态打字特效【支持多行文本】(含css实现闪烁光标,js动态改变setInterval定时器的时间间隔)
60 1
|
3月前
|
前端开发
css 实现打字特效(仅支持单行文本)
css 实现打字特效(仅支持单行文本)
28 0
|
JavaScript 前端开发 容器
|
前端开发 JavaScript 索引
CSS 实现打字效果
原文:CSS 实现打字效果 JS实现 最近做项目的时候需要实现一个字符逐个出现的打字效果,在网上一搜有个不错的jQuery插件Typed.js,效果很赞 $(function(){ $(".
746 0
|
2月前
|
前端开发
2s 利用 HTML+css动画实现企业官网效果
2s 利用 HTML+css动画实现企业官网效果
HTML+CSS 实现通用的企业官网页面(记得收藏)
HTML+CSS 实现通用的企业官网页面(记得收藏)
|
8天前
|
前端开发 JavaScript 搜索推荐
打造个人博客网站:从零开始的HTML和CSS之旅
【9月更文挑战第32天】在这个数字化的时代,拥有一个个人博客不仅是展示自我的平台,也是技术交流的桥梁。本文将引导初学者理解并实现一个简单的个人博客网站的搭建,涵盖HTML的基础结构、CSS样式的美化技巧以及如何将两者结合来制作一个完整的网页。通过这篇文章,你将学会如何从零开始构建自己的网络空间,并在互联网世界留下你的足迹。
|
8天前
|
前端开发 JavaScript 搜索推荐
打造个人博客网站:从零开始的HTML与CSS之旅
【9月更文挑战第31天】在这个数字时代,拥有一个个人博客网站是展示自我、分享知识和连接世界的重要方式。本文将引导你通过简单的HTML和CSS知识,一步步构建起你的在线空间。无论你是编程新手还是希望通过实践加深理解,这篇文章都将是你的理想指南。我们将探索基本概念,实现页面布局,并点缀以个性化样式,最终将静态页面转变为动态交互式网站。准备好了吗?让我们开始吧!
|
12天前
|
前端开发 数据安全/隐私保护 容器
HTML+CSS 水滴登录页
该代码实现了一个创意的水滴登录页面,包含一个水滴形状的登录框与两个按钮(忘记密码和注册)。登录框包括用户名、密码输入框及登录按钮。页面设计独特,采用渐变色与动态效果,增强了交互性和视觉美感。以下为关键实现步骤: - 重置默认样式。 - 设置页面背景颜色和尺寸。 - 定义登录表单容器的布局、位置和尺寸。 - 设置登录表单内容样式,包括3D效果和过渡动画。 - 创建伪元素增强水滴效果。 - 设定输入框容器和输入框样式。 - 为提交按钮、忘记密码和注册按钮设定特定样式,并添加悬停效果。