您好,登錄后才能下訂單哦!
這篇文章主要介紹了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); }
燒腦題
如下console.log的結果是什么?為什么?
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);
感謝你能夠認真閱讀完這篇文章,希望小編分享的“JS中閉包與定時器的示例分析”這篇文章對大家有幫助,同時也希望大家多多支持億速云,關注億速云行業資訊頻道,更多相關知識等著你來學習!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。