- 相關(guān)推薦
一道阿里巴巴Web前端面試題拓展
第二第三個問題由第一個拓展而來,先看問題吧:
第一問:
var a = 6;
setTimeout(function () {
alert(a); //輸出66
a = 666;},
1000);
a = 66;
第二問:
var a = 6;
setTimeout(function () {
var a = 666;
alert(a); // 輸出666,
}, 1000);
a = 66;
第三問:
var a = 6;
setTimeout(function () {
alert(a); // 輸出undefined,
var a=666;
}, 1000);
a = 66;
這三個問題涉及到了setTimeout的工作原理,執(zhí)行環(huán)境與作用域還有函數(shù)的創(chuàng)建與調(diào)用。
首先先說一下setTimeout(function(),ms)函數(shù),現(xiàn)在在我們的js文件中有這么一段代碼:setTimeout( a() , 5000 );。
在執(zhí)行流執(zhí)行到setTimeout代碼時,并不會原地踏步地等待執(zhí)行完畢后再向下執(zhí)行,而是會告訴瀏覽器,我這段代碼要等待5秒之后再執(zhí)行,然后立即向下執(zhí)行接下來的代碼。
現(xiàn)在可以先解決第一問了。
首先定義了一個局部變量a,并且a=6 。然后執(zhí)行流遇到了setTimeout(),告訴瀏覽器,我1秒之后再執(zhí)行這段代碼,此時a仍然為6。然后跳過setTimeout()中的代碼繼續(xù)向下執(zhí)行,就碰到了a=66,將a賦值為66 。一秒過去了之后,瀏覽器開始調(diào)用setTimeout()函數(shù)中的匿名函數(shù),遇到了alert(a),在此之前匿名函數(shù)中并沒有創(chuàng)造局部變量a,所以隨著作用域鏈由內(nèi)向外搜尋有沒有變量a。當(dāng)搜尋到外部函數(shù)的作用域時,發(fā)現(xiàn)a已經(jīng)被賦值成了66,則返回結(jié)果,最終彈出窗口顯示66。
第二問中,由于在setTimeout()的匿名函數(shù)中擁有了一個局部變量a,所以最后alert(a)輸出的是666,這一個沒什么可說的。
至于第三問的解答,涉及到了一個函數(shù)的創(chuàng)建與執(zhí)行的區(qū)別,讓我想起了C和C++中的函數(shù)創(chuàng)建執(zhí)行部分(更多的是本人的猜想,未經(jīng)求證),在進(jìn)入setTimeout()函數(shù)之后,我們得先創(chuàng)建一個函數(shù),然后才能執(zhí)行它,在創(chuàng)建函數(shù)的時候,會搜尋函數(shù)內(nèi)部是否有變量創(chuàng)建出來了。所以,當(dāng)執(zhí)行流遇到alert(a)的時候,開始搜尋當(dāng)前環(huán)境下有沒有a變量,最終發(fā)現(xiàn)了一個a變量,但是在未執(zhí)行var a=666之前,a并沒有被賦值,所以alert(a)的最終結(jié)果為undefined。
這三個問題涉及到了setTimeout的工作原理,執(zhí)行環(huán)境與作用域還有函數(shù)的創(chuàng)建與調(diào)用。
http://www.oriental01.com/【一道阿里巴巴Web前端面試題拓展】相關(guān)文章:
Web前端面試題目及答案06-30
前端工程師面試題10-20
阿里巴巴的HR10-14
阿里巴巴面試技巧07-19
Microsoft面試題09-04
iOS面試題07-10
公司面試題09-12
hibernate面試題10-18
英語面試題精選06-13
小升初面試題06-10