前端面試題每日3題——2022/08/30

1 以下代碼執(zhí)行后闸氮,控制臺(tái)中的輸出內(nèi)容為教沾?

for (let i = 0; i < 3; i++) {
  setTimeout(() => {
    console.log(i);
  });
}

for (var j = 0; j < 3; j++) {
  setTimeout(() => {
    console.log(j);
  });
}

2 以下代碼執(zhí)行后授翻,控制臺(tái)中的輸出內(nèi)容為?

if (!("a" in window)) {
  var a = 1;
}

if (!("b" in window)) {
  let b = 1;
}
console.log(window);
console.log(a);
console.log(b);

3 以下代碼執(zhí)行后巡语,控制臺(tái)中的輸出內(nèi)容為淮菠?

function fn() {
  var i = 0;
  return function () {
    console.log(i++);
  };
}
var f1 = fn();
var f2 = fn();
f1();
f1();
f2();

1、答案:0 1 2 3 3 3

解析:var 聲明的變量沒有塊級(jí)作用域理澎,在 for 循環(huán)中使用 var 聲明迭代變量 j 會(huì)導(dǎo)致所有 setTimeout 中使用的 j 指向同一個(gè)變量,而 setTimeout 屬于宏任務(wù)糠爬,執(zhí)行的時(shí)機(jī)在正常任務(wù)隊(duì)列之后举庶,即此處 for 循環(huán)退出之后開始執(zhí)行,此時(shí)迭代變量保存的是導(dǎo)致循環(huán)退出的值 3镀琉,因此所有 setTimeout 的回調(diào)函數(shù)都會(huì)輸出 3

而 let 聲明迭代變量時(shí)蕊唐,JS 引擎會(huì)為每個(gè)迭代循環(huán)聲明一個(gè)新的迭代變量替梨,每個(gè) setTimeout 引用的都是不同的變量實(shí)例装黑,所以最后輸出 0 1 2

2恋谭、答案:undefined 報(bào)錯(cuò):Uncaught ReferenceError: b is not defined

var 聲明的變量沒有塊級(jí)作用域挽鞠,并且存在變量提升,因此該題代碼等價(jià)于:

var a;
if (!("a" in window)) {
  a = 1;
}

此時(shí) a 為全局變量材义,而由 var 聲明的全局變量會(huì)成為 window 的屬性狮杨,因此 if 語句塊中的代碼不會(huì)執(zhí)行,所以 console.log(a) 輸出 undefined

而 let 聲明的變量存在塊級(jí)作用域的概念清寇,所以 let b 不會(huì)成為全局變量华烟,即使其成為全局變量持灰,也不會(huì)成為 window 的屬性,因?yàn)?let 聲明的全局變量不會(huì)成為 window 的屬性喂链,所以在 console.log(b) 所在的作用域(全局)中椭微,未聲明變量 b盲链,因此會(huì)報(bào)錯(cuò):Uncaught ReferenceError: b is not defined

3、答案:0 1 0

var 聲明的變量不存在塊級(jí)作用域本慕,但是存在局部作用域侧漓,此題中變量 i 的作用域?yàn)?fn 函數(shù)作用域

每次調(diào)用fn都會(huì)形成一個(gè)閉包,不同閉包之間是獨(dú)立的不會(huì)互相干擾

閉包會(huì)將 i 的值保存下來鉴象,多次調(diào)用 fn() 返回的函數(shù)會(huì)修改 i 的值

所以最終會(huì)輸出:0 1 0

公眾號(hào)【今天也要寫bug】

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末纺弊,一起剝皮案震驚了整個(gè)濱河市骡男,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌隔盛,老刑警劉巖吮炕,帶你破解...
    沈念sama閱讀 221,273評論 6 515
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件龙亲,死亡現(xiàn)場離奇詭異,居然都是意外死亡杜耙,警方通過查閱死者的電腦和手機(jī)佑女,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 94,349評論 3 398
  • 文/潘曉璐 我一進(jìn)店門团驱,熙熙樓的掌柜王于貴愁眉苦臉地迎上來嚎花,“玉大人劫恒,你說我怎么就攤上這事〈猿” “怎么了趣些?”我有些...
    開封第一講書人閱讀 167,709評論 0 360
  • 文/不壞的土叔 我叫張陵坏平,是天一觀的道長拢操。 經(jīng)常有香客問我,道長舶替,這世上最難降的妖魔是什么令境? 我笑而不...
    開封第一講書人閱讀 59,520評論 1 296
  • 正文 為了忘掉前任,我火速辦了婚禮顾瞪,結(jié)果婚禮上舔庶,老公的妹妹穿的比我還像新娘。我一直安慰自己陈醒,他們只是感情好惕橙,可當(dāng)我...
    茶點(diǎn)故事閱讀 68,515評論 6 397
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著钉跷,像睡著了一般弥鹦。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上爷辙,一...
    開封第一講書人閱讀 52,158評論 1 308
  • 那天彬坏,我揣著相機(jī)與錄音,去河邊找鬼犬钢。 笑死混滔,一個(gè)胖子當(dāng)著我的面吹牛坯屿,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播吠昭,決...
    沈念sama閱讀 40,755評論 3 421
  • 文/蒼蘭香墨 我猛地睜開眼府喳,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了申窘?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 39,660評論 0 276
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎,沒想到半個(gè)月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體浓领,經(jīng)...
    沈念sama閱讀 46,203評論 1 319
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡捎拯,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 38,287評論 3 340
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了没隘。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 40,427評論 1 352
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情,我是刑警寧澤浴骂,帶...
    沈念sama閱讀 36,122評論 5 349
  • 正文 年R本政府宣布,位于F島的核電站梯轻,受9級(jí)特大地震影響,放射性物質(zhì)發(fā)生泄漏伊诵。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,801評論 3 333
  • 文/蒙蒙 一唯袄、第九天 我趴在偏房一處隱蔽的房頂上張望恋拷。 院中可真熱鬧,春花似錦诀豁、人聲如沸娩践。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,272評論 0 23
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽旦事。三九已至,卻和暖如春单料,著一層夾襖步出監(jiān)牢的瞬間白对,已是汗流浹背蟀瞧。 一陣腳步聲響...
    開封第一講書人閱讀 33,393評論 1 272
  • 我被黑心中介騙來泰國打工切端, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人茵瀑。 一個(gè)月前我還...
    沈念sama閱讀 48,808評論 3 376
  • 正文 我出身青樓,卻偏偏與公主長得像,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 45,440評論 2 359

推薦閱讀更多精彩內(nèi)容