這次帶給大家JS的閉包與計時器,使用JS的閉包與定時器的注意事項有哪些,下面就是實戰案例,一起來看一下。
什麼是閉包? 有什麼作用
閉包就是能夠讀取其他函數內部變數的函數。
作用:1.可以讀取函數內部的變數2.讓這些變數的值始終保持在記憶體中。
setTimeout 0 有什麼作用
js運行是基於單線程的,意味著一段程式碼執行時,其他程式碼將進入佇列等待,一旦執行緒有空閒就執行後續程式碼。如果程式碼中設定了一個setTimeout,那麼瀏覽器就會在適當的時間,將程式碼插入任務佇列,如果這個時間設為0,就代表立即插入佇列,但並不是立即執行,仍然要等待前面程式碼執行完畢(其實有延時,具體是16ms還是4ms取決於瀏覽器)。所以setTimeout並不能保證執行的時間,是否及時執行取決於 JavaScript 執行緒是擁擠還是空閒。
程式碼
下面的程式碼輸出多少?修改程式碼讓fnArr[i]()輸出 i。使用兩種以上的方法
var fnArr = []; for (var i = 0; i < 10; i ++) { fnArr[i] = function(){ return i; }; } console.log( fnArr3 ); //
程式碼:
方法一:
var fnArr = []; for (var i = 0; i < 10; i ++) { fnArr[i] = (function(){ var index = i; var fn = function(){ return index } return fn }()); } console.log( fnArr3 ); //
方法二:
var fnArr = []; for (var i = 0; i < 10; i ++) { (function(n){ fnArr[i] = function(){ return n; } })(i) }; console.log( fnArr3 )
使用閉包封裝一個汽車對象,可以透過以下方式取得汽車狀態
var Car = //todo; Car.setSpeed(30); Car.getSpeed(); //30 Car.accelerate(); Car.getSpeed(); //40; Car.decelerate(); Car.decelerate(); Car.getSpeed(); //20 Car.getStatus(); // 'running'; Car.decelerate(); Car.decelerate(); Car.getStatus(); //'stop'; //Car.speed; //error
程式碼:
var Car = (function(){ var speed; function setSpeed(n){ speed = n } function getSpeed(){ return console.log(speed); } function accelerate(){ speed +=10 return speed; } function decelerate(){ speed -=10 return speed; } function getStatus(){ return console.log(speed===0?'stop':'running'); } return { setSpeed:setSpeed, getSpeed:getSpeed, accelerate:accelerate, decelerate:decelerate, getStatus:getStatus, } }()); Car.setSpeed(30); Car.getSpeed(); //30 Car.accelerate(); Car.getSpeed(); //40; Car.decelerate(); Car.decelerate(); Car.getSpeed(); //20 Car.getStatus(); // 'running'; Car.decelerate(); Car.decelerate(); Car.getStatus(); //'stop'; Car.speed(); //error
寫一個函數使用setTimeout模擬setInterval的功能
程式碼:
var i=0; function intv(){ setTimeout(function(){ console.log(i++); intv(); },1000); } intv();
寫一個函數,計算setTimeout最小時間粒度
程式碼:
function getmin(){ var i = 0; var start = Date.now(); var clock = setTimeout(function(){ i++; if(i === 1000){ clearTimeout(clock); var end = Date.now(); console.log((end-start)/i) } clock = setTimeout(arguments.callee,0) },0) } getmin()
下面這段程式碼輸出結果是? 為什麼?
var a = 1; setTimeout(function(){ a = 2; console.log(a); }, 0); var a ; console.log(a); a = 3; console.log(a);
這段程式碼的輸出結果為1;3;2,因為程式碼中設定了一個setTimeout,那麼瀏覽器就會在適當的時間,將程式碼插入任務佇列,如果這個時間設為0,就代表立即插入佇列,但並不是立即執行,仍然要等待前面程式碼執行完畢,所以要等程式碼全部執行完畢後才執行setTimeout(function(){a = 2;console.log(a); }, 0);。
下面這段程式碼輸出結果是? 為什麼?
var flag = true; setTimeout(function(){ flag = false; },0) while(flag){} console.log(flag);
不會輸出結果,因為setTimeout(function(){flag = false;},0)會在所有程式碼執行完畢後才運行,``flag初始值為true,所以while會一直循環下去,console.log(flag)也不會被訪問,但是由於某些瀏覽器會存在環路保護功能,所以也有可能輸出為true```。
下面這段程式碼輸出?如何輸出delayer: 0, delayer:1...(使用閉包來實現)
for(var i=0;i<5;i++){ setTimeout(function(){ console.log('delayer:' + i ); }, 0); console.log(i); }
代碼:
for(var i=0;i<5;i++){ (function(i){ setTimeout(function(){ console.log('delayer:' + i ); }, 0); })(i) console.log(i); }
燒腦題
function fn(a,b) { console.log(b); return { fn:function(c){ return fn(c,a); } }; } var a = fn(0); a.fn(1); a.fn(2); a.fn(3); var b = fn(0).fn(1).fn(2).fn(3); var c = fn(0).fn(1); c.fn(2); c.fn(3);
相信看了本文案例你已經掌握了方法,更多精彩請關注php中文網其它相關文章!
######以上是JS的閉包與定時器的詳細內容。更多資訊請關注PHP中文網其他相關文章!

HTML的核心目的在於讓瀏覽器理解並展示網頁內容。 1.HTML通過標籤定義網頁結構和內容,如、到、等。 2.HTML5增強了多媒體支持,引入了和標籤。 3.HTML提供了表單元素,支持用戶交互。 4.優化HTML代碼可提升網頁性能,如減少HTTP請求和壓縮HTML。

htmltagsareessentialforwebdevelopmentastheyandendenhancewebpages.1)semantictagsimproveaccessibilityandseo.2)semanteLayOut,語義和互動性。 3)poseriblesibilityandseoandseo.3)poseriblesoftagscanoftagscanoftagscanoptagscanoptimizeperefeneandimizeanDenSuroceRecRoscRoss-BrowserCrowserCercerComercompatibility。

一致的HTML編碼風格很重要,因為它提高了代碼的可讀性、可維護性和效率。 1)使用小寫標籤和屬性,2)保持一致的縮進,3)選擇並堅持使用單引號或雙引號,4)避免在項目中混合使用不同風格,5)利用自動化工具如Prettier或ESLint來確保風格的一致性。

在Bootstrap4中實現多項目輪播的解決方案在Bootstrap4中實現多項目輪播並不是一件簡單的事情。雖然Bootstrap...

如何實現鼠標滾動事件穿透效果?在我們瀏覽網頁時,經常會遇到一些特別的交互設計。比如在deepseek官網上,�...

無法直接通過CSS修改HTML視頻的默認播放控件樣式。 1.使用JavaScript創建自定義控件。 2.通過CSS美化這些控件。 3.考慮兼容性、用戶體驗和性能,使用庫如Video.js或Plyr可簡化過程。

在手機上使用原生select的潛在問題在開發移動端應用時,我們常常會遇到選擇框的需求。通常情況下,開發者傾...

在手機上使用原生select的弊端是什麼?在移動設備上開發應用時,選擇合適的UI組件是非常重要的。許多開發者�...


熱AI工具

Undresser.AI Undress
人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover
用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

Video Face Swap
使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱門文章

熱工具

DVWA
Damn Vulnerable Web App (DVWA) 是一個PHP/MySQL的Web應用程序,非常容易受到攻擊。它的主要目標是成為安全專業人員在合法環境中測試自己的技能和工具的輔助工具,幫助Web開發人員更好地理解保護網路應用程式的過程,並幫助教師/學生在課堂環境中教授/學習Web應用程式安全性。 DVWA的目標是透過簡單直接的介面練習一些最常見的Web漏洞,難度各不相同。請注意,該軟體中

Atom編輯器mac版下載
最受歡迎的的開源編輯器

VSCode Windows 64位元 下載
微軟推出的免費、功能強大的一款IDE編輯器

Dreamweaver Mac版
視覺化網頁開發工具

SublimeText3 Mac版
神級程式碼編輯軟體(SublimeText3)