欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

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

  發(fā)布時(shí)間:2022-07-25 16:34:41   作者: 月亮與六便士丶   我要評(píng)論
本文主要介紹了純CSS打字動(dòng)畫(huà)的實(shí)現(xiàn)示例,逐個(gè)顯示一段文本中的字符,模擬出一種打字的效果,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧

在一些技術(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ù)
  • 同樣,將 animationsteps() 也設(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 布局示例詳解

    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
  • CSS will-change 屬性示例詳解

    will-change 是一個(gè) CSS 屬性,用于告訴瀏覽器某個(gè)元素在未來(lái)可能會(huì)發(fā)生哪些變化,本文給大家介紹CSS will-change 屬性詳解,感興趣的朋友一起看看吧
    2025-04-07
  • CSS去除a標(biāo)簽的下劃線的幾種方法

    本文給大家分享在 CSS 中,去除a標(biāo)簽(超鏈接)的下劃線的幾種方法,本文給大家介紹的非常詳細(xì),感興趣的朋友一起看看吧
    2025-04-07
  • 前端高級(jí)CSS用法示例詳解

    在前端開(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
  • CSS @media print 使用詳解

    文章詳細(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

最新評(píng)論