亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

淺談JavaScript超時(shí)調(diào)用和間歇調(diào)用

 更新時(shí)間:2015年08月30日 16:55:53   投稿:hebedich  
JavaScript是單線程語(yǔ)言,但它允許通過(guò)設(shè)置超時(shí)值和間歇時(shí)間值來(lái)調(diào)度代碼在特定的時(shí)刻執(zhí)行。前者是在指定的時(shí)間過(guò)后執(zhí)行代碼,而后者則是每隔指定的時(shí)間就執(zhí)行一次代碼。

間歇調(diào)用

在JavaScript中間歇調(diào)用很常見(jiàn),setInterval,就是間隔一定的時(shí)間重復(fù)調(diào)用。

setInterval()方法接收兩個(gè)參數(shù):第一個(gè)參數(shù)可以是字符串,也可以是函數(shù),第二個(gè)參數(shù)是一個(gè)以毫秒為單位的數(shù)字,表示重復(fù)間隔的時(shí)長(zhǎng)。

參數(shù)是字符串

當(dāng)?shù)谝粋€(gè)傳遞參數(shù)是字符串時(shí),如下:

setInterval("alert('this is a string.')",1000);

這里的字符串是一段JavaScript代碼,和傳入的eval()函數(shù)的參數(shù)一樣,如果是有內(nèi)外兩個(gè)引號(hào)的話,記得引號(hào)不要相同就行了。

setInterval()會(huì)返回一個(gè)數(shù)值型的ID,這個(gè)ID是計(jì)劃執(zhí)行代碼的唯一標(biāo)識(shí)符,所以可以用它來(lái)取消重復(fù)操作。setInterval()對(duì)應(yīng)的一個(gè)取消該操作的方法:clearInterval(),當(dāng)然要取消重復(fù)操作的話,clearInterval()必須放在還沒(méi)有執(zhí)行完畢的時(shí)候。

比如:

var intervalId=setInterval(...);
clearInterval(intervalId);

首先我們獲取ID,然后將ID傳入clearInterval()中即可,因?yàn)槿∠僮骶o跟在setInterval()后面,所以可以立即取消,就和沒(méi)發(fā)生一樣。

參數(shù)是函數(shù)

因?yàn)楫?dāng)傳遞的參數(shù)是字符串的時(shí)候,可能會(huì)導(dǎo)致性能損失,所以一般情況下,用的最多的還是給它傳遞一個(gè)函數(shù)。

如下:

var num=0;
function increNum(){
 num++;
 if(num>=10){
  clearInterval(intervalId);
  alert('over');
 }
}
intervalId=setInterval(increNum,500);

該段程序設(shè)置了一個(gè)increNum函數(shù),并作為參數(shù)傳遞給setInterval(),同時(shí)當(dāng)重復(fù)運(yùn)行到10次的時(shí)候,取消運(yùn)行操作,彈出警告框。

超時(shí)調(diào)用

超時(shí)調(diào)用和間歇調(diào)用類(lèi)似,setTimeout(),它也接收兩個(gè)參數(shù),第一個(gè)可以是包含JavaScript代碼的字符串,也可是一個(gè)函數(shù),第二個(gè)參數(shù)是延時(shí)時(shí)間和setInterval()方法的參數(shù)是一樣。

但是這里要說(shuō)明一點(diǎn):

延時(shí)時(shí)間并不是說(shuō)經(jīng)過(guò)設(shè)定的延時(shí)后程序一定會(huì)執(zhí)行。

為什么呢?

因?yàn)镴avaScript是單線程解釋器,所以在一定的時(shí)間內(nèi)只能執(zhí)行一段代碼,不能同時(shí)執(zhí)行多段代碼,所以在JavaScript中有一個(gè)任務(wù)隊(duì)列,將要執(zhí)行的任務(wù)按照先后順序排在隊(duì)列中,設(shè)定的延時(shí)時(shí)間是經(jīng)過(guò)這段時(shí)間將當(dāng)前任務(wù)加入到任務(wù)隊(duì)列中。如果當(dāng)前沒(méi)有任務(wù)執(zhí)行,那么加入到任務(wù)隊(duì)列中的代碼立刻執(zhí)行,如果當(dāng)前還有正在執(zhí)行的代碼段,那么只有當(dāng)該代碼段執(zhí)行完畢后再執(zhí)行新加入的任務(wù)。

同樣,setTimeout()也有一個(gè)返回ID,也可以通過(guò)這個(gè)數(shù)值ID來(lái)取消超時(shí)調(diào)用,對(duì)應(yīng)的取消方法是clearTimeout()。

在這里,我們用超時(shí)調(diào)用方法來(lái)把間歇調(diào)用中的那段重復(fù)執(zhí)行的代碼復(fù)寫(xiě)一遍:

var num=0;
function increNum(){
 num++;
 if(num<=10){
  setTimeout(increNum,500);
 }else{
  alert('over');
 }
}
setTimeout(increNum,500);

這段程序也可以完成重復(fù)操作并在10次之后終止操作,和上述的setInterval()有區(qū)別的是它并沒(méi)有用返回的數(shù)值ID。

因?yàn)閟etInterval()是重復(fù)執(zhí)行,所以一直會(huì)有數(shù)值ID返回,所以必須得一直跟蹤這個(gè)數(shù)值ID,而setTimeout()執(zhí)行完畢后就不再執(zhí)行,所以我們不用跟蹤這個(gè)返回的數(shù)值ID,這就給我們帶來(lái)了一定的便利。

而且,后一個(gè)間歇調(diào)用可能會(huì)在前一個(gè)間歇調(diào)用還沒(méi)結(jié)束之前被調(diào)用,當(dāng)函數(shù)的執(zhí)行時(shí)間比間歇調(diào)用的時(shí)間長(zhǎng)的時(shí)候這種情況就會(huì)發(fā)生,所以綜上所述,用setTimeout()來(lái)模擬間歇調(diào)用是一種比較好的途徑。

當(dāng)然,在比較簡(jiǎn)單的程序中用setInterval()還是沒(méi)有很大問(wèn)題的(突然想起了一句話,存在即是合理的~~~~)。

相關(guān)文章

  • 小程序?qū)崿F(xiàn)發(fā)表評(píng)論功能

    小程序?qū)崿F(xiàn)發(fā)表評(píng)論功能

    這篇文章主要為大家詳細(xì)介紹了小程序?qū)崿F(xiàn)發(fā)表評(píng)論功能,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2018-07-07
  • JavaScript中的undefined學(xué)習(xí)總結(jié)

    JavaScript中的undefined學(xué)習(xí)總結(jié)

    這篇文章主要是對(duì)JavaScript中的undefined進(jìn)行了介紹,需要的朋友可以過(guò)來(lái)參考下,希望對(duì)大家有所幫助
    2013-11-11
  • 微信小程序獲取用戶openid的圖文教程(含源碼)

    微信小程序獲取用戶openid的圖文教程(含源碼)

    微信小程序的開(kāi)發(fā)過(guò)程中,有時(shí)前端需要獲取到openId來(lái)使用,下面這篇文章主要給大家介紹了關(guān)于微信小程序獲取用戶openid的相關(guān)資料,文中通過(guò)實(shí)例代碼介紹的非常詳細(xì),需要的朋友可以參考下
    2023-01-01
  • JavaScript簡(jiǎn)單遍歷DOM對(duì)象所有屬性的實(shí)現(xiàn)方法

    JavaScript簡(jiǎn)單遍歷DOM對(duì)象所有屬性的實(shí)現(xiàn)方法

    這篇文章主要介紹了JavaScript簡(jiǎn)單遍歷DOM對(duì)象所有屬性的實(shí)現(xiàn)方法,涉及JavaScript針對(duì)頁(yè)面元素屬性操作的相關(guān)技巧,具有一定參考借鑒價(jià)值,需要的朋友可以參考下
    2015-10-10
  • 解決JS外部文件中文注釋出現(xiàn)亂碼問(wèn)題

    解決JS外部文件中文注釋出現(xiàn)亂碼問(wèn)題

    中文亂碼在Java Web開(kāi)發(fā)中經(jīng)常出現(xiàn),這是由于不同的部分編碼不一樣造成的,一般在開(kāi)發(fā)中,我們把所有能設(shè)編碼的地方,全部設(shè)置成UTF-8,但是有時(shí)候還是會(huì)出現(xiàn)亂碼的情況。下面通過(guò)本文給大家分享JS外部文件中文注釋出現(xiàn)亂碼的解決方案,一起看看吧
    2017-07-07
  • js 下拉菜單點(diǎn)擊旁邊收起實(shí)現(xiàn)(踩坑記)

    js 下拉菜單點(diǎn)擊旁邊收起實(shí)現(xiàn)(踩坑記)

    這篇文章主要介紹了js 下拉菜單點(diǎn)擊旁邊收起實(shí)現(xiàn)(踩坑記),文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2019-09-09
  • uniapp使用uni-imei插件獲取手機(jī)的設(shè)備號(hào)

    uniapp使用uni-imei插件獲取手機(jī)的設(shè)備號(hào)

    uniapp框架是一款開(kāi)發(fā)跨平臺(tái)應(yīng)用的工具,它支持iOS、Android以及Web等多個(gè)平臺(tái),在這些平臺(tái)中,uniapp可以訪問(wèn)某些設(shè)備的硬件信息,這篇文章主要給大家介紹了關(guān)于uniapp使用uni-imei插件獲取手機(jī)設(shè)備號(hào)的相關(guān)資料,需要的朋友可以參考下
    2024-01-01
  • JavaScript中兩種鏈?zhǔn)秸{(diào)用實(shí)現(xiàn)代碼

    JavaScript中兩種鏈?zhǔn)秸{(diào)用實(shí)現(xiàn)代碼

    方法鏈一般適合對(duì)一個(gè)對(duì)象進(jìn)行連續(xù)操作(集中在一句代碼)。一定程度上可以減少代碼量,缺點(diǎn)是它占用了函數(shù)的返回值。
    2011-01-01
  • js實(shí)現(xiàn)的標(biāo)題欄新消息閃爍提示效果

    js實(shí)現(xiàn)的標(biāo)題欄新消息閃爍提示效果

    這篇文章主要介紹了js實(shí)現(xiàn)的標(biāo)題欄新消息閃爍提示效果,一些大型網(wǎng)站也會(huì)經(jīng)常用到這個(gè)效果,需要的朋友可以參考下
    2014-06-06
  • 一個(gè)不錯(cuò)的字符串轉(zhuǎn)碼解碼函數(shù)(自寫(xiě))

    一個(gè)不錯(cuò)的字符串轉(zhuǎn)碼解碼函數(shù)(自寫(xiě))

    一個(gè)不錯(cuò)的字符串轉(zhuǎn)碼解碼函數(shù),自己寫(xiě)的,有需要的朋友可以參考下
    2014-07-07

最新評(píng)論