使用JS與jQuery實現文字逐漸出現特效

来源:https://www.cnblogs.com/tianqingzx/archive/2019/03/13/10522498.html
-Advertisement-
Play Games

該需求出現原因:想要實現一個在一開始載入頁面時就出現一行文字逐漸出現的效果,且需要實現的是一種逐漸的過渡出現效果為不是一種生硬的突然間歇性出現。於是便開始嘗試利用最近正在學習的jQuery技術和JS實現。 【註】:該篇文章適合初學者閱讀,大佬請跳過。 【需要的知識點】:JS中利用Timing中的兩個 ...


該需求出現原因:想要實現一個在一開始載入頁面時就出現一行文字逐漸出現的效果,且需要實現的是一種逐漸的過渡出現效果為不是一種生硬的突然間歇性出現。於是便開始嘗試利用最近正在學習的jQuery技術和JS實現。

【註】:該篇文章適合初學者閱讀,大佬請跳過。

需要的知識點】:JS中利用Timing中的兩個靜態方法setTimeout()和clearTimeout()實現(詳細參考:http://www.w3school.com.cn/js/js_timing.asp),同時使用了一個遞歸小方法。

1、網頁簡單編寫:

 

 1 <!-- 使用標簽屬性onload: -->
 2 <!-- 該屬性實現在頁面載入時完成內部的相關函數方法:show() 事件-->
 3 
 4 <body onload="show()">
 5 
 6     <!-- 給需要的div命名為word,方便定位元素 -->
 7     <div id="word">
 8 
 9     </div>
10 </body>

 

2、編寫相關的css樣式表,這裡只列出主要的樣式:

1 <style>
2     #word>span{
3         opacity: 0;
4     }
5 </style>

該處的opacity:0實現使word下麵的所有span標簽中的字體變為透明色。

3、引入jQuery庫:

1 <script src="jquery-1.12.4.js"></script>

這裡使用1.x版本的最後一版1.12.4版,大家可以線上百度jQuery引入線上版。我這裡是在本地就有一個jQuery文檔了,所以可以直接引入。

4、編寫相關的jQuery入口函數:

<script language="javascript" type="text/javascript">
        $(function () { //jQuery的入口函數

              // 編寫相關的jQuery代碼與JS代碼...

        });
</script>

5、以下為主要代碼分塊描述:

 

 

 1 var str="英雄名稱:宮本武藏被動技能:宮本武藏的被動技能為'狩魔',使宮本武藏" +
 2         "釋放技能將會為下一次普通攻擊蓄力,造成額外30(+60%物理加成)點物理" +
 3         "傷害並減少所有技能1秒冷卻時間。";
 4         // 測試
 5         // console.log(str[3]);
 6         // console.log($.isArray(str));  //false
 7 
 8         // 向名為word的div添加指定字數個span標簽,方便操作
 9         for (var i=0; i<str.length; i++){
10             // 添加str的長度個span,每一個span裡面保存著一個文字
11             $("#word").append("<span>" + str[i] + "</span>");
12         }

 

這裡是用於預先將每一個文字添加進span標簽,當然使用div也可以不過這裡使用span標簽是因為它是inline元素,不用轉換類型。str是一個字元串,但是在進行isArray()判斷後可以看出其並不是數組,應該是一個偽數組,但依然可以使用str[i]取其中的單個文字。

 1 var j = 0;  // 用於計數
 2 
 3 // show()方法的另外一種書寫方式
 4 show = function () {
 5        // $("#word>span"):jQuery語法,選擇器,選中word其中的所有span標簽
 6        // eq():選擇元素,返回jQuery對象
 7        $("#word>span").eq(j).animate({opacity:"1"}, 100);
 8        j += 1;
 9        // setTimeout("要做的動作(方法名)", 時間(毫秒))
10        // 這裡用到了遞歸實現
11        var t = setTimeout("show()", 100);
12        if (j >= str.length){
13               clearTimeout(t);  // 清除延時動作,退出遞歸
14        }
15 }

setTimeout()和clearTimeout()可以自行去w3school查看,這裡不贅餘描述。

在setTimeout這裡使用遞歸實現文字的逐漸顯示,在完成前一個動畫的實現後才會繼續下一層遞歸的方法動畫實現。

$("#word>span");是jQuery語法,相當於css中的選擇器。

eq()方法用於返回專門的jQuery對象,animate()實現動畫效果:第一個是實現透明度的恢復(取值0-1),第二個參數實現效果作用時間。

 


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 最近面試有一個面試題,要求儘可能多的列舉數組去重的方法,現整理一下 1、最簡單的去重方法 2、排序後相鄰去除法 該方法存在一個問題,當數組中存在number類型的2,和string類型的‘2’時,因sort方法會調用每個數組項的toString()方法,得到字元串,然後再對得到的字元串進行排序。如對 ...
  • 分別通過JS,JAVA和MySql實現 1. JS方法 2. JAVA方法 3. MySql方法 ...
  • 今天需要做手機端的輸入表單自動生成器,突然就想到了手機端對input的輸入類型支持還不錯,於是翻遍了資料,有了下麵的使用方法,閑話少說,上正文: html5現在可以用的新input type類型一共有下麵類型 => <input type="email" /> <input type="url" / ...
  • 示例代碼: <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>lightbox</title> <link href="css/lightbox.css" rel="stylesheet"> <script t ...
  • 示例代碼: <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>Document</title> <link rel="stylesheet" href="../themes/default/default.cs ...
  • v-model用於數據的雙向綁定。bug不少,湊合看吧,主要是練習v-model。 ...
  • function myJquery(selector){ if(typeof selector=="string") { if (selector.charAt(0) == "<" && selector.slice(-1) == ">") { var ele = selector.slice(1, ...
  • 11111 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...