純CSS打字動(dòng)畫(huà)的實(shí)現(xiàn)示例

在一些技術(shù)網(wǎng)站中,經(jīng)常會(huì)看到這樣一種展示效果:逐個(gè)顯示一段文本中的字符,模擬出一種打字的效果。通過(guò)這種方式可以顯著地提升網(wǎng)頁(yè)設(shè)計(jì)感。
在大部分應(yīng)用中,都是通過(guò)使用 JS 腳本實(shí)現(xiàn)該方案,雖然效果很好,但是對(duì)于使用 JS 來(lái)操作出表現(xiàn)層的展示,總感覺(jué)有點(diǎn)奇怪,所以嘗試下只使用 CSS 來(lái)實(shí)現(xiàn)我們的打字動(dòng)畫(huà)~
通過(guò)CSS,無(wú)法實(shí)現(xiàn)像 JS 那樣一個(gè)字一個(gè)字的繪制在頁(yè)面上,那不如就換一個(gè)思路,讓容器寬度成為動(dòng)畫(huà)的主體,讓文字逐漸顯示出來(lái)。具體來(lái)說(shuō),最開(kāi)始容器的寬度是0,隨著動(dòng)畫(huà)的推進(jìn),一個(gè)字一個(gè)字的擴(kuò)張到它應(yīng)用的寬度。(需要注意,該方案僅適用于單行文本)
按照我們預(yù)想的思路,很容易完成下述代碼。
@keyframes typing { from { width: 0; } } h1 { width: 188px; animation: typing 8s; white-space: nowrap; overflow: hidden; }
但是從實(shí)現(xiàn)效果上看,并不是那么理想,我們需要的動(dòng)畫(huà)效果是逐字呈現(xiàn)而不是這樣的平滑顯示。
對(duì)于這個(gè)問(wèn)題,很顯然,我們會(huì)想到使用 steps()
來(lái)修復(fù),但是具體需要分多少步又是擺在我們面前的另一個(gè)難題。
要解決這個(gè)問(wèn)題,就需要說(shuō)到 ch
這個(gè) CSS 中基本用不到的長(zhǎng)度單位,它代表元素所用字體中“0”這一字形的寬度,如果使用的是等寬字體的話,那么“0”字形的寬度和其他所有字形的寬度是一樣的,所以很容易想到要解決上述問(wèn)題,其實(shí)只要:
- 將元素文字設(shè)置為等寬字體(實(shí)際上,應(yīng)用打字動(dòng)效的文字都場(chǎng)景大多是為展示代碼的形式,大部分情況下也都是使用都等寬字體)
- 元素的
width
設(shè)置為該元素中文字的個(gè)數(shù) - 同樣,將
animation
的steps()
也設(shè)置為元素的個(gè)數(shù)
@keyframes typing { from { width: 0; } } h1 { font-family: "Cascadia Code", Menlo, Monaco, "Courier New", monospace; width: 12ch; animation: typing 8s steps(12); white-space: nowrap; overflow: hidden; }
已經(jīng)基本實(shí)現(xiàn)我們想要的效果了,最后只要加上一個(gè)閃爍的光標(biāo)即可。可以通過(guò)使用偽元素生成光標(biāo),并通過(guò) opacity 屬性來(lái)實(shí)現(xiàn)閃爍效果:
@keyframes caret { 50% { opacity: 0; } } h1::after { content: ""; position: absolute; right: 0; width: 2px; top: 6px; bottom: 6px; background: #000; animation: caret 1s steps(1) infinite; }
到此這篇關(guān)于純CSS打字動(dòng)畫(huà)的實(shí)現(xiàn)示例的文章就介紹到這了,更多相關(guān)CSS打字動(dòng)畫(huà)內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章,希望大家以后多多支持腳本之家!
相關(guān)文章
- CSS Grid 是一種二維布局系統(tǒng),可以同時(shí)控制行和列,相比 Flex(一維布局),更適合用在整體頁(yè)面布局或復(fù)雜模塊結(jié)構(gòu)中,這篇文章主要介紹了前端CSS Grid 布局詳解,需要的朋2025-04-16
CSS Padding 和 Margin 區(qū)別全解析
CSS 中的 padding 和 margin 是兩個(gè)非?;A(chǔ)且重要的屬性,它們用于控制元素周?chē)目瞻讌^(qū)域,本文將詳細(xì)介紹 padding 和 margin 的概念、區(qū)別以及如何在實(shí)際項(xiàng)目中使用它們2025-04-07- will-change 是一個(gè) CSS 屬性,用于告訴瀏覽器某個(gè)元素在未來(lái)可能會(huì)發(fā)生哪些變化,本文給大家介紹CSS will-change 屬性詳解,感興趣的朋友一起看看吧2025-04-07
- 本文給大家分享在 CSS 中,去除a標(biāo)簽(超鏈接)的下劃線的幾種方法,本文給大家介紹的非常詳細(xì),感興趣的朋友一起看看吧2025-04-07
- 在前端開(kāi)發(fā)中,CSS(層疊樣式表)不僅是用來(lái)控制網(wǎng)頁(yè)的外觀和布局,更是實(shí)現(xiàn)復(fù)雜交互和動(dòng)態(tài)效果的關(guān)鍵技術(shù)之一,隨著前端技術(shù)的不斷發(fā)展,CSS的用法也日益豐富和高級(jí),本文將2025-04-07
css中的 vertical-align與line-height作用詳解
文章詳細(xì)介紹了CSS中的`vertical-align`和`line-height`屬性,包括它們的作用、適用元素、屬性值、常見(jiàn)使用場(chǎng)景、常見(jiàn)問(wèn)題及解決方案,感興趣的朋友跟隨小編一起看看吧2025-03-26淺析CSS 中z - index屬性的作用及在什么情況下會(huì)失效
z-index屬性用于控制元素的堆疊順序,值越大,元素越顯示在上層,它需要元素具有定位屬性(如relative、absolute、fixed或sticky),本文給大家介紹CSS 中z - index屬性的作用2025-03-21- 文章詳細(xì)介紹了CSS中的打印媒體查詢(xún)@mediaprint包括基本語(yǔ)法、常見(jiàn)使用場(chǎng)景和代碼示例,如隱藏非必要元素、調(diào)整字體和顏色、處理鏈接的URL顯示、分頁(yè)控制、調(diào)整邊距和背景等2025-03-18
CSS模擬 html 的 title 屬性(鼠標(biāo)懸浮顯示提示文字效果)
本文介紹了如何使用CSS模擬HTML的title屬性,通過(guò)鼠標(biāo)懸浮顯示提示文字效果,通過(guò)設(shè)置`.tipBox`和`.tipBox.tipContent`的樣式,實(shí)現(xiàn)了提示內(nèi)容的隱藏和顯示,感興趣的朋友一起2025-03-10前端 CSS 動(dòng)態(tài)設(shè)置樣式::class、:style 等技巧(推薦)
本文介紹了Vue.js中動(dòng)態(tài)綁定類(lèi)名和內(nèi)聯(lián)樣式的兩種方法:對(duì)象語(yǔ)法和數(shù)組語(yǔ)法,通過(guò)對(duì)象語(yǔ)法,可以根據(jù)條件動(dòng)態(tài)切換類(lèi)名或樣式;通過(guò)數(shù)組語(yǔ)法,可以同時(shí)綁定多個(gè)類(lèi)名或樣式,此外2025-02-26