# 有趣!把 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

# 多个 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

# 加入到地址栏和标题

接下来我们把这个动画加入到我们的地址栏和标题!

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

大功告成,让我看看骚气的地址栏和标题吧