純CSS打字動畫的實現(xiàn)示例

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