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

JavaScript中setInterval()用法舉例詳解

 更新時間:2023年10月09日 10:07:40   作者:孫?悟?空  
這篇文章主要給大家介紹了關于JavaScript中setInterval()用法的相關資料,setInterval()方法可按照指定的周期(以毫秒計)來調用函數(shù)或計算表達式,文中通過代碼示例介紹的非常詳細,需要的朋友可以參考下

1 基本語法

setInterval() 是 JavaScript 中的一個內置函數(shù),它用于在指定的間隔時間內重復執(zhí)行一段代碼,實現(xiàn)周期性操作。該函數(shù)的語法如下:

setInterval(function, milliseconds, param1, param2, ...)

2 參數(shù)說明

  • function:必需,要重復執(zhí)行的函數(shù)或代碼塊。
  • milliseconds:必需,重復執(zhí)行的時間間隔(以毫秒為單位)。
  • param1, param2, ...:可選,傳遞給要執(zhí)行的函數(shù)的參數(shù)。如果無須傳遞參數(shù),則省略此參數(shù)。

注意:

如果 setInterval() 函數(shù)的第一個參數(shù)是一個函數(shù),那么該函數(shù)會在每個時間間隔后被調用,直到計時器被取消。

如果 setInterval() 函數(shù)的第一個參數(shù)是一個字符串,那么該字符串會被解釋為一段要執(zhí)行的 JavaScript 代碼。這種用法已經被棄用,不建議使用。

如果 setInterval() 函數(shù)的時間間隔設為 0 或負數(shù),那么該函數(shù)會立即執(zhí)行第一個參數(shù)所表示的函數(shù)或代碼,并且不會周期性地執(zhí)行。

如果 setInterval() 函數(shù)的時間間隔設為較小的值,那么可能會因為瀏覽器的性能限制而導致定時器不準確。建議將時間間隔設為 100 毫秒或以上,以保證計時器的準確性。

3 使用示例

使用匿名函數(shù)作為第一個參數(shù),用來輸出當前時間,間隔時間是1000毫秒即1秒鐘。

// 每秒鐘輸出一次當前時間
setInterval(function() {
  console.log(new Date().toLocaleTimeString());
}, 1000);

4 停止 setInterval() 方法

setInterval() 方法會返回一個計時器ID,可以通過該計時器ID來取消計時器的執(zhí)行,方法如下:

intervalId = setInterval(function() {
  console.log(new Date().toLocaleTimeString());
}, 1000);
clearInterval(intervalId );

其中,intervalId 是一個變量,用于保存 setInterval() 方法返回的計時器對象ID。調用 clearInterval() 方法后,就可以取消計時器的執(zhí)行。

示例: 打印5次后,取消計時器的執(zhí)行。

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
</head>
<body>
    <script>
        var counter = 0;
        maxNum = 5;
        function myFunc() {
            var date = new Date();
            console.log(date.toLocaleTimeString());
            counter++;
            if (counter == maxNum) {
                clearInterval(intervalId);
                console.log('已打印' + maxNum + "次");
            }
        }
        var intervalId = setInterval(myFunc, 1000);
    </script>
</body>
</html>

打印結果:

在這里插入圖片描述

附:JavaScript定時器setInterval如何做到在定義時先執(zhí)行一遍

JavaScript中的定時器setInterval是計時到才會開始執(zhí)行,有沒有辦法再定義的時候就先調用一遍,然后再定時執(zhí)行呢?

有,只要定義一個返回“定時執(zhí)行函數(shù)”(如“waitUploadThenSave”)的“執(zhí)行過程”, 將“定時執(zhí)行函數(shù)”保存并調用一次,并且執(zhí)行過程中返回該“定時執(zhí)行函數(shù)”,將該“執(zhí)行過程”的主體作為定時器要定時執(zhí)行的function即可。可參考以下代碼理解:

var count = 0;
var bNoNeedTimerRun = false;
var id = setInterval(
    (function () {
        var waitUploadThenSave = function () {
            //等待上傳執(zhí)行完成后保存數(shù)據(jù):
            if (pThis.fileList.every(x => x.status == 'success')) {
                clearInterval(id);
                if (bNoNeedTimerRun) {
                    //初始運行時就檢測到都已上傳完成,則定時運行中無須做任何事情,清除定時器即可
                    return;
                }
                if (!id) {
                    //初始運行時未完成id賦值,此時就檢測到都已上傳完成,則無需再定時檢測運行
                    bNoNeedTimerRun = true;
                }                  
                setTimeout(() => pThis.saveTaskInfo(), 20); //wait for running on-success callback for upload
                return;
            } else {
                if (++count > 600) {
                    clearInterval(id);
                    pThis.$message({
                        message: `上傳資料${pThis.task.TaskText ? "“" + pThis.task.TaskText + "”" : ""}執(zhí)行超時,未執(zhí)行保存!`,
                        type: 'error'
                    });
                }
            }
        }
        waitUploadThenSave();
        return waitUploadThenSave;
    })()
    , 50);

封裝

每次都寫這么多是不是既麻煩又啰嗦,代碼還不簡潔,于是我封裝了如下“timerCheckRun”方法,用的時候只需傳入“條件、滿足條件時執(zhí)行的方法、超時提示” 參數(shù)即可:

//定時判斷執(zhí)行:
timerCheckRun: function (checkCondition, trueAction, timeOutAction, initRun = true, interval = 50, times = 600) {				
	var iCount = 0;
	var bDoAtInit = false;
	var timerId = setInterval((function () {
		var fn = function () {
			if (bDoAtInit) {
				clearInterval(timerId);
				return;     //初始運行時就已滿足條件并執(zhí)行,則無須開啟定時器,關閉定時器即可,無須重復執(zhí)行
			}
			if (checkCondition()) {
				clearInterval(timerId);
				if (initRun) {
					if (!timerId) {
						bDoAtInit = true;   //初始運行時未完成timerId賦值,此時如果已滿足條件,則做好標記,定時器中關閉定時執(zhí)行即可
					}
				}
				trueAction();
			} else {
				if (++iCount > times) {
					clearInterval(timerId);
					timeOutAction();
				}
			}
		};
		if (initRun) {
			fn();
		}
		return fn;
	})(), interval);
}

調用實例:

$JVue.timerCheckRun(
    () => _self.fileList.every(x => x.status == 'success') && (_self.cert.AttachFileIDsArray || []).length - (_self.cert.PendingDeleteAttachFileIDsArray || []).length == _self.fileList.length,
    () => _self.saveCertInfo(),
    () => _self.$message({
        message: '上傳資質附件超時,未執(zhí)行保存!',
        type: 'error'
    })
);

總結

到此這篇關于JavaScript中setInterval()用法舉例詳解的文章就介紹到這了,更多相關JS中setInterval()用法內容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!

相關文章

  • js在數(shù)組中刪除重復的元素自保留一個(兩種實現(xiàn)思路)

    js在數(shù)組中刪除重復的元素自保留一個(兩種實現(xiàn)思路)

    遍歷要刪除的數(shù)組arr, 把元素分別放入另一個數(shù)組tmp中,在判斷該元素在arr中不存在才允許放入tmp中,具體實現(xiàn)如下,需要的朋友可以看看
    2014-08-08
  • JavaScript學習筆記之取數(shù)組中最大值和最小值

    JavaScript學習筆記之取數(shù)組中最大值和最小值

    在實際業(yè)務中有的時候要取出數(shù)組中的最大值或最小值。但在數(shù)組中并沒有提供arr.max()和arr.min()這樣的方法。那么是不是可以通過別的方式實現(xiàn)類似這樣的方法呢?那么今天我們就來整理取出數(shù)組中最大值和最小值的一些方法,需要的朋友一起學習吧
    2016-03-03
  • js讀寫(刪除)Cookie實例詳解

    js讀寫(刪除)Cookie實例詳解

    js操作Cookie包括:寫cookies、讀取cookies、刪除cookies以及使用示例,感興趣的朋友可以參考下哈
    2013-04-04
  • 深入理解Javascript中的作用域鏈和閉包

    深入理解Javascript中的作用域鏈和閉包

    之前我們講到數(shù)組遍歷, 本文我們更進一步, 講講如何提高遍歷的效率. 下面這篇文章主要深入的介紹了Javascript中作用域鏈和閉包的相關資料,需要的朋友可以參考下
    2017-04-04
  • llqrcode js識別二維碼解析二維碼信息實例

    llqrcode js識別二維碼解析二維碼信息實例

    這篇文章主要為大家介紹了llqrcode js識別二維碼解析二維碼信息實例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2022-11-11
  • JS中傳遞參數(shù)的幾種不同方法比較

    JS中傳遞參數(shù)的幾種不同方法比較

    本篇文章主要介紹了JS中傳遞參數(shù)的幾種不同方法。具有一定的參考價值,下面跟著小編一起來看下吧
    2017-01-01
  • 微信小程序實現(xiàn)簡單Tab切換效果

    微信小程序實現(xiàn)簡單Tab切換效果

    這篇文章主要為大家詳細介紹了微信小程序實現(xiàn)簡單Tab切換效果,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2021-05-05
  • select自定義小三角樣式代碼(實用總結)

    select自定義小三角樣式代碼(實用總結)

    這篇文章主要介紹了select自定義小三角樣式,通過css HTML js 代碼詳細展示了操作過程,自定義小三角樣式,也可以做出select文字居中的效果,需要的朋友可以參考下
    2017-08-08
  • Javascript的表單驗證-揭開正則表達式的面紗

    Javascript的表單驗證-揭開正則表達式的面紗

    Javascript的表單驗證-揭開正則表達式的面紗在本文重點介紹,感興趣的朋友一起學習吧
    2016-03-03
  • 利用Javascript裁剪圖片并存儲的簡單實現(xiàn)

    利用Javascript裁剪圖片并存儲的簡單實現(xiàn)

    裁剪圖片對我們來說是再熟悉不過的了,最近工作中就又遇到了這個需求,所以想著干脆整理下來,方法大家和自己在需要的時候參考學習,所以這篇文章主要介紹了利用Javascript裁剪圖片并存儲的簡單實現(xiàn),后端PHP處理我用的是THINKPHP框架,需要的朋友可以參考下。
    2017-03-03

最新評論