node.js學習筆記之定時器的第三個參數(shù)

相對于定時器setTimeout 和 setInterval 的如何在指定時間之后執(zhí)行被大家所熟悉來說,這兩個系統(tǒng)函數(shù)的第三個參數(shù)可能有些同學還不是太清楚,我也是剛發(fā)現(xiàn)的,現(xiàn)學現(xiàn)賣一下。

創(chuàng)新互聯(lián)專注為客戶提供全方位的互聯(lián)網(wǎng)綜合服務,包含不限于成都網(wǎng)站建設、做網(wǎng)站、亞東網(wǎng)絡推廣、微信小程序、亞東網(wǎng)絡營銷、亞東企業(yè)策劃、亞東品牌公關、搜索引擎seo、人物專訪、企業(yè)宣傳片、企業(yè)代運營等,從售前售中售后,我們都將竭誠為您服務,您的肯定,是我們最大的嘉獎;創(chuàng)新互聯(lián)為所有大學生創(chuàng)業(yè)者提供亞東建站搭建服務,24小時服務熱線:028-86922220,官方網(wǎng)址:bm7419.com

這兩個函數(shù)的基本用法很簡單,setTimeout是在指定時間之后執(zhí)行一次函數(shù)體;setInterval是每過一段時間就執(zhí)行一次,直到清除該定時器。應用如下:

//setTimeout

setTimeout(function(){
    console.log("this is console.log");
},100);

//setTimeout 在100毫秒之后輸出"this is console.log",定時器執(zhí)行完畢;



//setInterval

let m = 1;
let t = setInterval(function(){
    console.log(m);
    m++;
    if(m>10){
        clearInterval(t);
    }
},100);

//setInterval 每100毫秒輸出一次m的值,當m大于10,清除定時器,也就不再輸出了。

其實定時器還可以有第三個參數(shù),甚至第四第N個參數(shù),當然N是不能大于函數(shù)所能接受的參數(shù)最大值的。

從第三個參數(shù)開始,包括第三個參數(shù)都將會當做定時器的回調函數(shù)的參數(shù)依次傳入回調函數(shù)。

//setTimeout

setTimeout(function(l,m,n){
	console.log(l,m,n);
},100 ,1,10,100);

//setTimeout 分別傳入了第三四五個參數(shù),在回調函數(shù)中也同時接收了三個參數(shù),最終輸出為
//1 10 100

//setInterval

let m = 1;
let s = setInterval(function(x,y,z){
	console.log(x,y,z);
	m++;
	if(m>10){
		clearInterval(s);
	}
},100,m,m*10,m*100)

//setInterval 也和setTimeout一樣從第三個參數(shù)開始都會按順序傳入回調函數(shù)。
///須要注意的是如果外部參數(shù)是值類型,不論第三四五參數(shù)如何變化,
//回調函數(shù)所接收的參數(shù)只是第一次傳入的值
//上面的console.log(x,y,z)輸出將會是
//1 10 100
//1 10 100
//1 10 100
//1 10 100
//1 10 100
//1 10 100
//1 10 100

//但如果外部參數(shù)如果是引用類型,比如是一個obj,那么,每次執(zhí)行時是可以得到不同的數(shù)據(jù)的,例如:
let m = {a:1};
let s = setInterval(function(x){
    console.log(x);
    m.a++;
    if(m.a>10){
        clearInterval(s);
    }
},100,m)

// 那么,上面console.log(x)的輸出將會是:
//{ a: 1 }
//{ a: 2 }
//{ a: 3 }
//{ a: 4 }
//{ a: 5 }
//{ a: 6 }
//{ a: 7 }
//{ a: 8 }
//{ a: 9 }
//{ a: 10 }

當前名稱:node.js學習筆記之定時器的第三個參數(shù)
標題鏈接:http://bm7419.com/article22/jdgojc.html

成都網(wǎng)站建設公司_創(chuàng)新互聯(lián),為您提供企業(yè)網(wǎng)站制作、動態(tài)網(wǎng)站、網(wǎng)站改版、云服務器營銷型網(wǎng)站建設、搜索引擎優(yōu)化

廣告

聲明:本網(wǎng)站發(fā)布的內容(圖片、視頻和文字)以用戶投稿、用戶轉載內容為主,如果涉及侵權請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內容未經允許不得轉載,或轉載時需注明來源: 創(chuàng)新互聯(lián)

網(wǎng)站托管運營