這篇文章主要講解了“一道面試題考驗(yàn)JS的基本功”,文中的講解內(nèi)容簡(jiǎn)單清晰,易于學(xué)習(xí)與理解,下面請(qǐng)大家跟著小編的思路慢慢深入,一起來(lái)研究和學(xué)習(xí)“一道面試題考驗(yàn)JS的基本功”吧!
創(chuàng)新互聯(lián)建站是一家集網(wǎng)站建設(shè),驛城企業(yè)網(wǎng)站建設(shè),驛城品牌網(wǎng)站建設(shè),網(wǎng)站定制,驛城網(wǎng)站建設(shè)報(bào)價(jià),網(wǎng)絡(luò)營(yíng)銷(xiāo),網(wǎng)絡(luò)優(yōu)化,驛城網(wǎng)站推廣為一體的創(chuàng)新建站企業(yè),幫助傳統(tǒng)企業(yè)提升企業(yè)形象加強(qiáng)企業(yè)競(jìng)爭(zhēng)力??沙浞譂M(mǎn)足這一群體相比中小企業(yè)更為豐富、高端、多元的互聯(lián)網(wǎng)需求。同時(shí)我們時(shí)刻保持專(zhuān)業(yè)、時(shí)尚、前沿,時(shí)刻以成就客戶(hù)成長(zhǎng)自我,堅(jiān)持不斷學(xué)習(xí)、思考、沉淀、凈化自己,讓我們?yōu)楦嗟钠髽I(yè)打造出實(shí)用型網(wǎng)站。
// 求出如下題目結(jié)果 ({} + {}).length ([] + []).length (function() {}).length
這道題目乍一看可能會(huì)讓你有點(diǎn)懵,你可能會(huì)想:一個(gè)對(duì)象和一個(gè)對(duì)象相加能得到什么?還能求出其長(zhǎng)度?
其實(shí)這道題目相當(dāng)考驗(yàn)了作為一位web前端開(kāi)發(fā)工程師的基本功
在看到這個(gè)題目之后,我們首先分析一下情況:
1、({} + {}).length
兩個(gè)空對(duì)象相加,肯定不是數(shù)值運(yùn)算,那么只有可能是字符串連接了,那你可能會(huì)得到 “{}{}” 這樣的結(jié)果,其實(shí)不然,因?yàn)槟愫鲆暳俗址谶B接時(shí)默認(rèn)會(huì)調(diào)用相應(yīng)的toString()方法
一個(gè)空對(duì)象調(diào)用toString()方法會(huì)得到什么?
({}).toString() // "[object Object]"
得到是 “[object Object]” 這樣的字符串,長(zhǎng)度為15,那么兩個(gè)空對(duì)象相加之后,其長(zhǎng)度則為30
({} + {}).length // 相當(dāng)于 ({}.toString() + {}.toString()).length // 也就是 "[object Object][object Object]",求得這個(gè)字符串長(zhǎng)度為30
2、([] + []).length
有了第一道題的經(jīng)驗(yàn),那么你可能會(huì)這么想:兩個(gè)空數(shù)組相加,一定也是字符串連接,也會(huì)調(diào)用其toString()方法,最終相當(dāng)于求 “[object Array][object Array]” 這個(gè)字符串的長(zhǎng)度,從而得出最終結(jié)果28
但是,數(shù)組的toString()方法是被重寫(xiě)過(guò)的
[1, 2, 3].toString() // 得到的是 "1,2,3" 這樣由逗號(hào)分割元素的字符串
如果一個(gè)空數(shù)組調(diào)用toString()方法,得到的只會(huì)是空字符串“”
所以,這道題的最終結(jié)果為0
3、(function() {}).length
有了前兩道題目的經(jīng)驗(yàn),那你可能會(huì)很自然的想到:這里的function也是會(huì)調(diào)用toString()方法的。如果你這樣想,那就是被前兩道題目誤導(dǎo)了:函數(shù)的長(zhǎng)度是其形參的個(gè)數(shù),所以最終結(jié)果是0
感謝各位的閱讀,以上就是“一道面試題考驗(yàn)JS的基本功”的內(nèi)容了,經(jīng)過(guò)本文的學(xué)習(xí)后,相信大家對(duì)一道面試題考驗(yàn)JS的基本功這一問(wèn)題有了更深刻的體會(huì),具體使用情況還需要大家實(shí)踐驗(yàn)證。這里是創(chuàng)新互聯(lián),小編將為大家推送更多相關(guān)知識(shí)點(diǎn)的文章,歡迎關(guān)注!