打字机效果的实现与应用

前言

在 web 应用中,模拟编辑器或者模拟输入框中文字啪啦啪啦输入的效果,往往能够吸引人们的眼球,让用户的注意力聚焦在输入的内容上,其实使用的是 web 动画模拟打字机效果,本文将和大家探讨打字机效果的实现方式以及应用。

纯 css 实现

最简单的方式是莫过于直接使用 CSS 。大概思路是借助 CSS3 的 @keyframe 动画来不断改变包含文字的容器的宽度,超出容器部分的文字隐藏不展示。

<style> .typing {font-size: 20px;/* 初始宽度为0 */width: 0;height: 30px;border-right: 1px solid darkgray;animation: write 4s steps(14) forwards,blink 0.5s steps(1) infinite;overflow: hidden;}@keyframes write {0% {width: 0;}100% {width: 240px;}}@keyframes blink {50% {/* transparent是全透明黑色(black)的速记法,即一个类似rgba(0,0,0,0)这样的值。 */border-color: transparent; /* #00000000 */}} </style>

<body><div class="typing">自在,轻盈,我本不想停留</div>
</body> 

Steps(<number_of_steps>,<direction>)

animation steps 可以让动画断断续续,而非连续执行。接收两个参数:

第一个参数指定动画分割的段数;

第二个参数可选,接受 start 和 end 两个值,指定在每个间隔的起点或是终点发生阶跃变化,默认为 end。

可以看到其实现原理很简单,打字效果其实就是改变容器的宽度实现的。 初始文字是全部在页面上的,只是容器的宽度为 0,设置文字超出部分隐藏,然后不断改变容器的宽度; 设置 border-right,并在关键帧上改变 border-colortransparent,右边框就像闪烁的光标了。

优点是简单,缺点也是有的,首先我们要先获得文本的宽度,上面的截图就是因为宽度写错了,导致光标在文字后面,然后只支持 1 行。若想要支持多行,就得使用 JavaScript 了。

js 实现

setInterval 实现

<style> /* 产生光标闪烁的效果 */#content::after{content: '|';color:#000;animation: blink 1s infinite;}@keyframes blink{from{opacity: 0;}to{opacity: 1;}} </style>
<div id='content'></d
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值