搜尋
首頁web前端css教學CSS 實現打字效果

CSS 實現打字效果

Feb 10, 2017 pm 03:50 PM
css

JS實作

最近做專案的時候需要實現一個字符逐個出現的打字效果,在網上一搜有個不錯的jQuery插件Typed.js,效果很讚

CSS 实现打字效果

<p></p>

<script></script>
<script>
  $(function(){
      $(".element").typed({
        strings: ["First sentence.", "Second sentence."],
        typeSpeed: 0
      });
  });
</script>

具體用法可以看看項目地址,帶註釋的源碼200多行,不算複雜

實現方法也不神奇,大多數人肯容易可以想到,用js逐個向容器內添加字符,作者做了很多字符的出來還有速度神馬的,我們可以擼一個簡單的

var s = 'Hello World! Hello World! Hello World!';
var con = $('.container');
var index = 0;
var length = s.length;
var tId = null;

function start(){
  con.text('');
  
  tId=setInterval(function(){
    con.append(s.charAt(index));
    if(index++ === length){
    clearInterval(tId);
    index = 0;
    start()
    }
  },100);
}

start();

JS Bin


CSS實現

如果對細節和瀏覽器相容性要求的不是很嚴格,我們可以透過CSS3實現

animation-ti CSS3的動畫都接觸過,我們平常也這麼用

animation: animation-name animation-duration animation-iteration-count

animation: name 5s infinite;

其實完整版的animation參數很多,也可以寫成分別的屬性

    animation-name
  1. animation-du-du-duion function
  2. animation-delay
  3. animation-iteration-count
  4. animation-direction
  5. animation-direction
  6. 的,jQuery動畫的時候我們用的liner參數就是這意思,但CSS3提供了一些其它的變化方式由animation-timing-function屬性指定

ease

-
  1. ease-out

  2. ease-in-out

  3. step-start

  4. 每種動畫效果都可以對應一種貝塞爾曲線cubic-bezier可以幫我直觀的看一下貝塞爾曲線效果,這裡不多說了
  5. steps

  6. 我們看一下steps的效果,其實顧名思義就可以想到steps什麼意思,就像俄羅斯方塊的小格子往下掉也是動畫,但是不是連續的,更像是逐幀的,steps就是實現這種效果的
  7. steps的語法

    steps(number_of_steps, [start|end])
  8. number_of_steps 動畫分為多少步執行

  9. direction 動畫顯示狀態,end:預設值,第一幀開始前顯示,start:第一幀結束後顯示

  10. 看科學的圖片幫助理解

看個科學的圖片幫助理解

了這些我們就能做個好玩兒的效果了

JS Bin
  • .walk {
      width: 125px;
      height: 150px;
      background: url(http://www.php.cn/) left;
      -webkit-animation:anima 1s steps(16) infinite ;
    }
    
    @-webkit-keyframes anima{
        from { background-position:2000px 0;}
        to {background-position:0px 0;}
    }
  • 打字效果
  • 打字效果也就可想而知了,改變容器寬度即可(只能單行使用,還得做到每步增加長度和字母寬度一致,還是js好其實)

    .typing{
        width:250px;
        white-space:nowrap;
        overflow:hidden;
        -webkit-animation: type 3s steps(50, end) infinite;
      animation: type 3s steps(50, end) infinite;
    }
    
    
    @-webkit-keyframes type{
        from { width: 0;}
    }
    
    @keyframes type{
        from { width: 0;}
    }
  • JS Bin

更多CSS 實現打字效果相關文章請關注PHP中文網!

陳述
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
'訂閱播客”鏈接應在哪裡?'訂閱播客”鏈接應在哪裡?Apr 16, 2025 pm 12:04 PM

有一段時間,iTunes是播客中的大狗,因此,如果您將“訂閱播客”鏈接到喜歡:

瀏覽器引擎多樣性瀏覽器引擎多樣性Apr 16, 2025 pm 12:02 PM

當他們在2013年去Chrome時,我們失去了歌劇。與Edge今年早些時候也進行了同樣的交易。邁克·泰勒(Mike Taylor)稱這些變化為“減少

網絡共享的UX注意事項網絡共享的UX注意事項Apr 16, 2025 am 11:59 AM

從垃圾點擊誘餌網站到大多數出版物的最多,共享按鈕長期以來一直無處不在。然而,這些

每周平台新聞:Apple部署網絡組件,漸進的HTML渲染,自託管關鍵資源每周平台新聞:Apple部署網絡組件,漸進的HTML渲染,自託管關鍵資源Apr 16, 2025 am 11:55 AM

在本週的綜述中,Apple進入Web組件,Instagram如何插入腳本以及一些思考的食物,以進行自託管關鍵資源。

git Pathspecs以及如何使用它們git Pathspecs以及如何使用它們Apr 16, 2025 am 11:53 AM

當我查看GIT命令的文檔時,我注意到其中許多人都有選擇。我最初以為這只是一個

產品圖像的彩色拾取器產品圖像的彩色拾取器Apr 16, 2025 am 11:49 AM

聽起來有點像一個困難的問題,不是嗎?我們經常沒有成千上萬種顏色的產品鏡頭,以便我們可以隨身攜帶。我們也不是

黑暗模式與React和Themeprovider切換黑暗模式與React和Themeprovider切換Apr 16, 2025 am 11:46 AM

我喜歡網站具有“暗模式”選項時。黑暗模式使我更容易閱讀網頁,並幫助我的眼睛更放鬆。許多網站,包括

帶有HTML對話框元素的一些動手帶有HTML對話框元素的一些動手Apr 16, 2025 am 11:33 AM

這是我第一次查看HTML元素。我已經意識到了一段時間,但是尚未將其旋轉。它很酷,

See all articles

熱AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool

Undress AI Tool

免費脫衣圖片

Clothoff.io

Clothoff.io

AI脫衣器

AI Hentai Generator

AI Hentai Generator

免費產生 AI 無盡。

熱門文章

R.E.P.O.能量晶體解釋及其做什麼(黃色晶體)
1 個月前By尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.最佳圖形設置
1 個月前By尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.如果您聽不到任何人,如何修復音頻
1 個月前By尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.聊天命令以及如何使用它們
1 個月前By尊渡假赌尊渡假赌尊渡假赌

熱工具

Atom編輯器mac版下載

Atom編輯器mac版下載

最受歡迎的的開源編輯器

PhpStorm Mac 版本

PhpStorm Mac 版本

最新(2018.2.1 )專業的PHP整合開發工具

禪工作室 13.0.1

禪工作室 13.0.1

強大的PHP整合開發環境

WebStorm Mac版

WebStorm Mac版

好用的JavaScript開發工具

SublimeText3 Mac版

SublimeText3 Mac版

神級程式碼編輯軟體(SublimeText3)