溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務(wù)條款》

如何使用CSS3模擬打字效果

發(fā)布時間:2020-12-23 09:43:09 來源:億速云 閱讀:261 作者:小新 欄目:web開發(fā)

小編給大家分享一下如何使用CSS3模擬打字效果,希望大家閱讀完這篇文章后大所收獲,下面讓我們一起去探討吧!

一、使用CSS3實現(xiàn)打字效果原理

要模擬打字的效果,就需要讓字符一個一個逐步顯示。

這里是通過改變?nèi)萜鞯膶挾?,讓容器的寬度?逐步增加,每次增加的寬度為每個字符的寬度,這樣就可以模擬打字的效果。

為了增強真實性,可以加上光標的閃爍效果,這樣就可以比較好的模擬出打字的效果了。

需要實現(xiàn)的點:

  • 怎么使用CSS讓文本容器的寬度逐步增加

  • 怎么讓容器每次增加的寬度等于每個字符的寬度

  • 怎么模擬光標的閃爍效果

對應(yīng)實現(xiàn)方法:

  • 使用CSS3中的animation實現(xiàn)動畫效果

  • 利用animation中的steps實現(xiàn)逐步播放動畫

  • 利用文本容器的右邊框動畫實現(xiàn)光標閃爍效果

二、實現(xiàn)

1、英文的打字效果

如何使用CSS3模擬打字效果

html:

<h2>A miss is as good as a mile.</h2>

css實現(xiàn):

@keyframes typing {
    from { width: 0}
}
@keyframes blink-caret {
    50% { border-color: transparent; }
}
 
h2 {
    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是為了讓光標閃爍的正常一點
}

這里因為是實現(xiàn)英文的打字效果,所以字體使用的是等寬字體:monospace,配合長度單位 ch (1ch就是當前字體下數(shù)字0的寬度),在等寬字體下,其它字符的寬度也等于1ch。這樣就可以設(shè)置文本容器的寬度 = 所有字符個數(shù) * 1ch。

讓文本容器的寬度從0逐步增加到實際寬度利用的是animation的steps。

steps可以讓動畫分成多少步去播放,像這里因為有28個字符,要讓一個一個字符顯示,就把連續(xù)的動畫分成28步來播放。

blink-caret動畫是實現(xiàn)光標的閃爍效果的,改變右邊框的透明度重復(fù)播放實現(xiàn)。

2、中文的打字效果

如何使用CSS3模擬打字效果

中文的打字效果和英文不同的點就在于在等寬字體monospace下,中文的一個字符等于 2ch,所以文本容器的寬度 = 中文字符個數(shù) * 2ch。

看完了這篇文章,相信你對如何使用CSS3模擬打字效果有了一定的了解,想了解更多相關(guān)知識,歡迎關(guān)注億速云行業(yè)資訊頻道,感謝各位的閱讀!

向AI問一下細節(jié)

免責聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關(guān)證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI