摘要:我們經(jīng)常希望一段文本中的字符逐個顯示,模擬出一種打字的效果。類似于終端命令行的感覺。
我們經(jīng)常希望一段文本中的字符逐個顯示,模擬出一種打字的效果。類似于終端命令行的感覺。最終效果
用JS去實現(xiàn):html:
js代碼:
const $ = attr => document.querySelector(attr); const textDom = $(".text"); const cursorDom = $(".cursor"); const input = (text) => { const textArr = text.split(""); let index = 0; const timer = setInterval(() => { const showText = textArr.slice(0, index).join(""); textDom.innerHTML = showText; index++; if (index > textArr.length) clearInterval(timer); }, 100); setInterval(() => { if (cursorDom.style.display === "none") { cursorDom.style.display = "inline"; } else { cursorDom.style.display = "none"; } }, 500); } input("The ZGMF-X20A Strike Freedom Gundam (aka Strike Freedom, Freedom) is the successor of the ZGMF-X10A Freedom.");用CSS3去實現(xiàn):
JS實現(xiàn)給人的感覺又臭又長,那能不能用CSS去實現(xiàn)呢?
html:
The ZGMF-X20A Strike Freedom Gundam (aka Strike Freedom, Freedom) is the successor of the ZGMF-X10A Freedom.
@keyframes typing { from { width: 0 } } @keyframes caret { 50% { border-right-color: transparent; } } h1 { font: bold 200% Consolas, Monaco, monospace; width: 108ch; white-space: nowrap; overflow: hidden; border-right: .05em solid; animation: typing 10.8s steps(108), caret 1s steps(1) infinite; }
字符串長度是108;
總結:js實現(xiàn)不用考慮兼容性,CSS3實現(xiàn)的需要考慮兼容性,還要兼顧字符串的長度and寬度且不能換行==,不能換行,不過使用起來似乎更簡單一些,具體的取舍還是看個人習慣。
補充:以前看某公司的主頁有這個打字動畫的效果,今天看發(fā)現(xiàn)有個代碼高亮的效果,于是優(yōu)化了代碼:
//... const timer = setInterval(() => { const showText = textArr.slice(0, index).join(""); textDom.innerHTML = showText; let current = text.substr(index, 1); if (current === "<") { index = text.indexOf(">", index) + 1; } else { index++; } if (index > textArr.length) clearInterval(timer); }, 100); //... input("The ZGMF-X20A Strike Freedom Gundam (aka Strike Freedom, Freedom) is the successor of the ZGMF-X10A Freedom.");
效果似乎還是不一樣,我要的效果應該是輸入結束的時候才高亮,我先看看,實現(xiàn)了再補充...
繼續(xù)補充:看來只能祭出強無敵的正則匹配了==
//... const timer = setInterval(() => { const showText = textArr.slice(0, index).join("").replace(/([sS]*)/ig, "$1"); textDom.innerHTML = showText; let current = text.substr(index, 1); if (current === "<") { index = text.indexOf(">", index) + 1; } else { index++; } if (index > textArr.length) clearInterval(timer); }, 100); //... input("The ZGMF-X20A Strike Freedom Gundam (aka Strike Freedom, Freedom) is the successor of the ZGMF-X10A Freedom.");
完成
完整代碼:
自動打字 >>>The ZGMF-X20A Strike Freedom Gundam (aka Strike Freedom, Freedom) is the successor of the ZGMF-X10A Freedom.
文章版權歸作者所有,未經(jīng)允許請勿轉載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉載請注明本文地址:http://systransis.cn/yun/51078.html
摘要:我們經(jīng)常希望一段文本中的字符逐個顯示,模擬出一種打字的效果。類似于終端命令行的感覺。 我們經(jīng)常希望一段文本中的字符逐個顯示,模擬出一種打字的效果。類似于終端命令行的感覺。最終效果 用JS去實現(xiàn): html: js代碼: const $ = attr => document.querySelector(attr); const textDom = $(.text); const cu...
摘要:庫一個用來在中創(chuàng)建炫酷的浮動粒子的庫一個用來在中創(chuàng)建物體和空間的庫快速實現(xiàn)全屏滾動特性打字機效果滾動到某個元素位置時觸發(fā)一個功能語法高亮使用創(chuàng)建漂亮的圖表能夠明顯加速網(wǎng)站加載時間,鼠標時預加載資源另一個圖表庫一個基于動畫和平移的雪碧圖庫實現(xiàn) Javascript 庫 Particles.js? 一個用來在 web 中創(chuàng)建炫酷的浮動粒子的庫 Three.js? 一個用來在 web 中創(chuàng)...
摘要:經(jīng)過一番研究,我收集了個最好的庫,你可以用在自己的項目中。該庫于年月首次推出,目前仍有近名參與者開發(fā)。超過的,是一個動畫庫,可以處理屬性單個轉換或任何屬性,以及對象。對智能設備的方向作出反應的視差引擎快速創(chuàng)建漂亮的動畫。 翻譯:瘋狂的技術宅原文:https://blog.bitsrc.io/11-jav... 當我想要在網(wǎng)上找一個簡潔的 Javascript 動效庫時,總是發(fā)現(xiàn)很多推...
摘要:利用實現(xiàn)動畫效果內容皮球掉地上反彈起來純實現(xiàn)效果圖片移動實現(xiàn)打字輸入效果效果更多點我看效果博客放在上了,歡迎大家,我會持續(xù)更新一些效果。 利用 CSS3 實現(xiàn)動畫效果 showImg(https://segmentfault.com/img/bVUATb?w=189&h=267); 內容 皮球掉地上反彈起來 純 CSS 實現(xiàn) gif 效果 圖片移動 實現(xiàn)打字輸入效果 效果 // h...
摘要:超過的星星,是一個動畫庫,可以處理屬性,單個轉換,或任何屬性以及對象。超過星星,這個動畫庫大小只有。超過星星,這個庫基允許你以選定的速度為字符串創(chuàng)建打字動畫。 想閱讀更多優(yōu)質文章請猛戳GitHub博客,一年百來篇優(yōu)質文章等著你! 1.Three.js showImg(https://segmentfault.com/img/bVbkQ4X?w=551&h=358); 超過46K的星星,...
閱讀 786·2023-04-25 17:33
閱讀 3641·2021-07-29 14:49
閱讀 2488·2019-08-30 15:53
閱讀 3442·2019-08-29 16:27
閱讀 2011·2019-08-29 16:11
閱讀 1038·2019-08-29 14:17
閱讀 2446·2019-08-29 13:47
閱讀 2024·2019-08-29 13:28