0%

Javascript打字机效果实现

一、如题

  • 尝试用原生js,实现一下标题描述的效果
  • 不知道还有没有更好的方法,如果各位有更好的方法,欢迎留言。
  • 代码如下,用到了定时器。
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>测试</title>

<style>
.main{
width: 1120px;
margin: 0px auto;
}

.main .content-container p{
display: none;
}
.main .content-container .title{
font-size: 20px;
font-weight: bold;
}
</style>
</head>
<body>
<div class="main">
<div class="content-container">
<p>我是谁????</p>
<p>你是谁????</p>

<p class="title">赤壁</p>
<p>折戟沉沙铁未销,</p>
<p>自将磨洗认前朝。</p>
<p>东风不与周郎便,</p>
<p>铜雀春深锁二乔</p>
</div>

<br/>
<br/>
<br/>
<div class="content-container">
<p class="title">《落花》</p>
<p>高阁客竟去,</p>
<p>小园花乱飞。</p>
<p>参差连曲陌,</p>
<p>迢递送斜晖。</p>
</div>

</div>

<script>
let initTime = 0;
let speed = 50;
window.onload=function (){
let container =document.getElementsByClassName("content-container");
for (let i = 0; i < container.length; i++) {
let childNodes = container[i].getElementsByTagName("p");
for (let j = 0; j < childNodes.length; j++) {
const value = childNodes[j].innerText;
printf(childNodes[j],initTime);
initTime+=value.length*speed;
}
}
}

function printf(el,addTime){
const value = el.innerText;
let arr = value.split('');
for (let j = 0; j < arr.length; j++) {
setTimeout(()=>{
el.style.setProperty('display', 'block', 'important');
el.innerText=arr.slice(0,j+1).toString().replaceAll(",",'');
},speed*j+addTime)
}

}
</script>

</body>
</html>

示例图如下:

二、更简单的方法

  • 除了上面其实还有更简单的方法
  • 获取原生元素的 innerHTML,也是通过定时器给它显示,但是比上面更简单
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>test</title>
</head>
<body>

<div id="content" style="display: none">
<span style="color: red;">abc</span>
<span class="code">abc</span>
<p>spanasdf</p>
</div>

<script>

window.onload = function () {
Element.prototype.typeWriter = function (speed) {
let d = this;
let c = d.innerHTML;
let b = 0;
d.innerHTML = "";
// 显示
d.style.setProperty('display', 'block', 'important');
let e = setInterval(function () {
let f = c.substr(b, 1);
if (f == "<") {
b = c.indexOf(">", b) + 1;
} else {
b++;
}
d.innerHTML = c.substring(0, b) + (b & 1 ? "_" : "");
if (b >= c.length) {
clearInterval(e)
}
}, speed)
return this;
}

document.getElementById("content").typeWriter(100);

}


</script>
</body>

</html>

三、还有开源的第三方库

  • typed.js
  • typewriter.js
  • 看需求,如果是比较复杂的,就可以使用第三方库,毕竟封装了很多常用方法
  • 不用自己造轮子
您的打赏,是我创作的动力!不给钱?那我只能靠想象力充饥了。