相對于定時器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)