# 有趣!把 Emoji 动画加到你的地址栏和标题里
今天看到在掘金看到一篇同样是非常有趣的文章用 JavaScript 和 Emoji 做地址栏动画
我先在迫不及待想 把他加到我的博客里!
Github 代码地址:https://github.com/zenoslin/javascript-demo/tree/master/js/Emoji-in-bar
# 单个 Emoji 动画
首先,想让我们做一个简单的 Emoji 动画.
let EmojiArr = ['🌑', '🌒', '🌓', '🌔', '🌝', '🌖', '🌗', '🌘'],
str = ""
function loop() {
str = EmojiArr[Math.floor((Date.now()/100)%f.length)];
setTimeout(loop, 50);
}
loop();
1
2
3
4
5
6
7
2
3
4
5
6
7
# 多个 Emoji 动画
我想要一堆月亮老公公轮着播,这样才炫酷。
let emojiArr = ['🌑', '🌘', '🌗', '🌖', '🌝', '🌔', '🌓', '🌒'],
stateArr = [0, 0, 0, 0],
m = 0,
str = ""
function loop() {
let s = '',
x = 0
if (!m) {
while (stateArr[x] == 4) { //满月时
x++
}
if (x >= stateArr.length) {
m = 1
}else {
stateArr[x]++
}
} else {
while (stateArr[x] == 0) {
x++
}
if (x >= stateArr.length) {
m = 0
}else {
stateArr[x]++
if (stateArr[x] == 8) { //全黑时
stateArr[x] = 0
}
}
}
stateArr.forEach(function (n) {
str += emojiArr[n]
})
setTimeout(loop, 50)
}
loop()
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
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
# 加入到地址栏和标题
接下来我们把这个动画加入到我们的地址栏和标题!
let emojiArr = ['🌑', '🌘', '🌗', '🌖', '🌝', '🌔', '🌓', '🌒'],
stateArr = [0, 0, 0, 0],
m = 0,
titleStr = document.title
function loop() {
let s = '',
x = 0
if (!m) {
while (stateArr[x] == 4) { //满月时
x++
}
if (x >= stateArr.length) {
m = 1
} else {
stateArr[x]++
}
} else {
while (stateArr[x] == 0) {
x++
}
if (x >= stateArr.length) {
m = 0
} else {
stateArr[x]++
if (stateArr[x] == 8) { //全黑时
stateArr[x] = 0
}
}
}
stateArr.forEach(function (n) {
s += emojiArr[n]
})
location.hash = s
document.title = titleStr + s
setTimeout(loop, 50)
}
window.addEventListener('load', function () {
loop()
})
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
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
大功告成,让我看看骚气的地址栏和标题吧