国产一区二区精品-国产一区二区精品久-国产一区二区精品久久-国产一区二区精品久久91-免费毛片播放-免费毛片基地

千鋒教育-做有情懷、有良心、有品質(zhì)的職業(yè)教育機(jī)構(gòu)

手機(jī)站
千鋒教育

千鋒學(xué)習(xí)站 | 隨時隨地免費(fèi)學(xué)

千鋒教育

掃一掃進(jìn)入千鋒手機(jī)站

領(lǐng)取全套視頻
千鋒教育

關(guān)注千鋒學(xué)習(xí)站小程序
隨時隨地免費(fèi)學(xué)習(xí)課程

當(dāng)前位置:首頁  >  技術(shù)干貨  > 從React中的短語列表中鍵入動畫

從React中的短語列表中鍵入動畫

來源:千鋒教育
發(fā)布人:syq
時間: 2022-09-22 13:24:30 1663824270

  你一定看過所有這些很酷的動畫,其中單詞只是在頁面上自動鍵入? 有沒有想過在 React 中是如何完成的?

從React中的短語列表中鍵入動畫

在這里,我將逐步指導(dǎo)您制作具有附加功能的打字動畫,其中每2秒隨機(jī)選擇一個短語并鍵入它。

從 React 中的短語列表中鍵入動畫95

  先決條件

  React 鉤子的基本知識,如使用狀態(tài)和使用效果。

  步驟1

  在組件中導(dǎo)入要播放動畫的掛鉤。在這里,我們將使用使用狀態(tài)和使用效果鉤子。

從 React 中的短語列表中鍵入動畫169

  第 2 步

  我們需要一個數(shù)組來存儲我們想要使用的短語,如下所示:

從 React 中的短語列表中鍵入動畫204

  然后,我們將需要一些狀態(tài),它們是:

  文本:頁面上顯示的當(dāng)前文本

  全文:我們希望看到的最終文本

  索引:這是頁面上顯示的字符的當(dāng)前索引。

從 React 中的短語列表中鍵入動畫273

  第 3 步

  現(xiàn)在我們需要編寫鍵入動畫邏輯。

  邏輯:隨著索引的增加,我們將 fullText 狀態(tài)的下一個字符添加到文本狀態(tài)中,最終顯示在我們的頁面上。

  我們希望每200毫秒增加一次索引,所以我們可以使用超時函數(shù)(內(nèi)置于JS中)來實(shí)現(xiàn),這將像這樣實(shí)現(xiàn):

從 React 中的短語列表中鍵入動畫401

  步驟4

  需要使用使用效果掛鉤,每次索引值更改時調(diào)用 timeOut 函數(shù)。

  因此,在繼續(xù)制作動畫之前,我們會檢查索引是否小于全文的長度。如果索引超過長度,則無需進(jìn)一步動畫,因?yàn)槲覀兊?fullText 已經(jīng)顯示。

從 React 中的短語列表中鍵入動畫510

  步驟5

  更改全文以從我們的文本列表數(shù)組中隨機(jī)選擇一個短語。

  只有當(dāng)索引超過全文的長度時,才會發(fā)生這種情況(因?yàn)橹挥羞@樣,才會顯示以前的全文)。所以這將是另一個條件。

  在這里,我們需要 textList 的長度,以便為 fullText 選擇一個介于 0 和 l 之間的隨機(jī)索引。

從 React 中的短語列表中鍵入動畫652

  現(xiàn)在,需要做些什么來隨機(jī)選擇一個新短語,每2秒?

  我們需要將文本狀態(tài)的值更改為空 (“ ”)

  我們需要將全文的值更改為文本列表的隨機(jī)索引位置。

  我們需要將索引設(shè)置為 0,以便它從 fullText 的初始位置開始。

  我們需要將所有這些放在一個超時函數(shù)中,該函數(shù)每2秒觸發(fā)一次

從 React 中的短語列表中鍵入動畫792

  將步驟 5 代碼放在您在步驟 4 中創(chuàng)建的 useEffect 掛鉤的 else 條件中。

從 React 中的短語列表中鍵入動畫840

  步驟6

  將文本呈現(xiàn)在您希望顯示的位置:

從 React 中的短語列表中鍵入動畫862

  最終代碼:

從 React 中的短語列表中鍵入動畫870

  瞧!有你很酷的打字動畫。

tags:
聲明:本站稿件版權(quán)均屬千鋒教育所有,未經(jīng)許可不得擅自轉(zhuǎn)載。
10年以上業(yè)內(nèi)強(qiáng)師集結(jié),手把手帶你蛻變精英
請您保持通訊暢通,專屬學(xué)習(xí)老師24小時內(nèi)將與您1V1溝通
免費(fèi)領(lǐng)取
今日已有369人領(lǐng)取成功
劉同學(xué) 138****2860 剛剛成功領(lǐng)取
王同學(xué) 131****2015 剛剛成功領(lǐng)取
張同學(xué) 133****4652 剛剛成功領(lǐng)取
李同學(xué) 135****8607 剛剛成功領(lǐng)取
楊同學(xué) 132****5667 剛剛成功領(lǐng)取
岳同學(xué) 134****6652 剛剛成功領(lǐng)取
梁同學(xué) 157****2950 剛剛成功領(lǐng)取
劉同學(xué) 189****1015 剛剛成功領(lǐng)取
張同學(xué) 155****4678 剛剛成功領(lǐng)取
鄒同學(xué) 139****2907 剛剛成功領(lǐng)取
董同學(xué) 138****2867 剛剛成功領(lǐng)取
周同學(xué) 136****3602 剛剛成功領(lǐng)取
相關(guān)推薦HOT
深度學(xué)習(xí)模型權(quán)重h5、weights、ckpt、pth有什么區(qū)別?

1.來源框架不同h5格式通常用于Keras和TensorFlow框架,weights用于Darknet框架,ckpt是TensorFlow框架的一種格式,而pth則主要用于PyTorch框架...詳情>>

2023-10-15 00:05:17
大數(shù)據(jù)測試工程師需要具備哪些技能?

一、理解大數(shù)據(jù)概念大數(shù)據(jù)測試工程師需要理解大數(shù)據(jù)的基本概念和原理,如分布式存儲、MapReduce、實(shí)時計(jì)算等。他們還需要了解如何處理大規(guī)模的...詳情>>

2023-10-14 23:43:03
為什么SpringBoot的 jar 可以直接運(yùn)行?

一、JAR文件的結(jié)構(gòu)與執(zhí)行方式Spring Boot的JAR包是Java Archive的縮寫,它是一種壓縮文件格式,可以將Java項(xiàng)目的類文件、資源文件以及依賴庫等...詳情>>

2023-10-14 23:01:49
站群服務(wù)器是什么?

站群服務(wù)器的含義與用途站群服務(wù)器主要用于支持站群,即由一組相互鏈接的網(wǎng)站組成的群體。這些網(wǎng)站通常由同一組織或個人擁有,并且經(jīng)常會互相鏈...詳情>>

2023-10-14 22:46:12
自編碼器是什么?

一、自編碼器原理自編碼器的設(shè)計(jì)靈感源于神經(jīng)科學(xué)中關(guān)于感知系統(tǒng)的認(rèn)知原理,它的核心思想是將輸入數(shù)據(jù)經(jīng)過編碼過程,形成一個隱藏層的特征表示...詳情>>

2023-10-14 22:41:10
快速通道