php打字效果,使用CSS3模拟打字效果(代码实例)

本篇文章给大家通过代码实例来介绍一下使用CSS3模拟中文/英文打字效果的方法。有一定的参考价值,有需要的朋友可以参考一下,希望对大家有所帮助。

733d05e360e1ad0a2def559bda4add8f.png

一、使用CSS3实现打字效果原理

要模拟打字的效果,就需要让字符一个一个逐步显示。

这里是通过改变容器的宽度,让容器的宽度从0逐步增加,每次增加的宽度为每个字符的宽度,这样就可以模拟打字的效果。

为了增强真实性,可以加上光标的闪烁效果,这样就可以比较好的模拟出打字的效果了。

需要实现的点:怎么使用CSS让文本容器的宽度逐步增加

怎么让容器每次增加的宽度等于每个字符的宽度

怎么模拟光标的闪烁效果

对应实现方法:使用CSS3中的animation实现动画效果

利用animation中的steps实现逐步播放动画

利用文本容器的右边框动画实现光标闪烁效果

二、实现

1、英文的打字效果

4d58837440cfd3c9e1f60f82cd5d53c2.gif

html:

A miss is as good as a mile.

css实现:@keyframes typing {

from { width: 0}

}

@keyframes blink-caret {

50% { border-color: transparent; }

}

h1 {

font: 200% monospace;

border-right: .08em solid;

width: 28ch;

white-space: nowrap;

overflow: hidden;

animation: typing 10s steps(28, end),

blink-caret .5s step-end infinite alternate; //这里的alternate是为了让光标闪烁的正常一点

}

这里因为是实现英文的打字效果,所以字体使用的是等宽字体:monospace,配合长度单位 ch (1ch就是当前字体下数字0的宽度),在等宽字体下,其它字符的宽度也等于1ch。这样就可以设置文本容器的宽度 = 所有字符个数 * 1ch。

让文本容器的宽度从0逐步增加到实际宽度利用的是animation的steps。

steps可以让动画分成多少步去播放,像这里因为有28个字符,要让一个一个字符显示,就把连续的动画分成28步来播放。

blink-caret动画是实现光标的闪烁效果的,改变右边框的透明度重复播放实现。

2、中文的打字效果

585f5ee7e08e200795bfaa95b52ce0d0.gif

中文的打字效果和英文不同的点就在于在等宽字体monospace下,中文的一个字符等于 2ch,所以文本容器的宽度 = 中文字符个数 * 2ch。

更多编程相关知识,请访问:编程入门!!

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值