一道優(yōu)雅面試題分析js中fn()和return fn()的區(qū)別
在js中,經(jīng)常會遇到在函數(shù)里調(diào)用其它函數(shù)的情況,這時候會有 fn() 這種調(diào)用方式,還有一種是 return fn() 這種調(diào)用方式,一些初學(xué)者經(jīng)常會被這兩種方式給繞暈了。這里用一個優(yōu)雅的面試題來分析一下兩種方式的不同之處。
var i = 0; function fn(){ i++; if(i < 10){ fn(); }else{ return i; } } var result = fn(); console.log(result);
這是一道隱藏了坑的面試題,看似很簡單,大部分人可能想都不想就答出了10。而實際上運行可知打印出來的是 undefined。這道陷阱題很直觀的體現(xiàn)出了前面所說的問題,當(dāng)我們將執(zhí)行fn的那一行修改為:
var i = 0; function fn(){ i++; if(i < 10){ return fn(); }else{ return i; } } var result = fn(); console.log(result);
這時,會發(fā)現(xiàn)打印出來的結(jié)果終于不負(fù)眾望的是 10 了。
為什么這里加不加return區(qū)別會這么大?
這里的主要原因很簡單,JavaScript的函數(shù)都是有默認(rèn)返回值的,如果函數(shù)結(jié)尾不寫return,會默認(rèn)返回undefined,這就是為什么在chrome的console控制臺里,寫代碼經(jīng)常下面會出現(xiàn)一行undefined的原因。
再仔細(xì)看看這個例子,當(dāng)i自增到9的時候,也就是倒數(shù)第二次遞歸調(diào)用fn的那一次,如果沒有return,這一次執(zhí)行完fn,會默認(rèn)return undefined,而不會繼續(xù)下一次遞歸了。當(dāng)加上了 return,在這里則會繼續(xù)最后一次遞歸,即i=10的時候,跳入else里面返回得到正確的10。
說到這里,可以引申出一個更為經(jīng)典的例子,著名的二分查找法:
var mid = Math.floor((arr.length - 1) / 2); function search(n, mid) { if (n > arr[mid]) { mid = Math.floor((mid + arr.length) / 2); return search(n, mid); } else if (n < arr[mid]) { mid = Math.floor((mid - 1) / 2); return search(n, mid); } else { return mid; } } var index = search(n, mid); console.log(index);
二分查找法也是需要多次遞歸調(diào)用,很多新手在第一次實現(xiàn)這個算法的時候經(jīng)常會犯的一個錯誤就是忘記在遞歸的函數(shù)前加上return,最后導(dǎo)致返回結(jié)果是undefined,這里的道理也和前面是類似的,不加return,會導(dǎo)致遞歸后,直接返回undefined,不會繼續(xù)下一次遞歸。
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
- JavaScript跳出循環(huán)的三種方法(break, return, continue)
- 淺析JavaScript中break、continue和return的區(qū)別
- javascript中break,continue和return語句用法小結(jié)
- javaScript如何跳出多重循環(huán)break、continue
- JavaScript Break 和 Continue區(qū)別教程
- javascript中關(guān)于break,continue的特殊用法與介紹
- Javascript基礎(chǔ)教程之break和continue語句
- js中return false(阻止)的用法
- Javascript中的return作用及javascript return關(guān)鍵字用法詳解
- javascript中return,return true,return false三者的用法及區(qū)別
- JS中實現(xiàn)函數(shù)return多個返回值的實例
- JavaScript中break、continue和return的用法區(qū)別實例分析
相關(guān)文章
手寫Spirit防抖函數(shù)underscore和節(jié)流函數(shù)lodash
這篇文章主要介紹了手寫Spirit防抖函數(shù)underscore和節(jié)流函數(shù)lodash,接下來將會帶你們了解下這兩者的區(qū)別,以及我們該如何手寫實現(xiàn)這兩個函數(shù)2022-03-03Textbox控件注冊回車事件及觸發(fā)按鈕提交事件具體實現(xiàn)
Lyncplus客戶端中訪問Web頁面時遇到了TextBox控件回車自動完成按鈕的提交事件失效的情況,于是上網(wǎng)查找相關(guān)的介紹最終解決了這兩個問題,感興趣的你可以參考下或許對你有所幫助2013-03-03JS如何根據(jù)條件取出數(shù)組中對應(yīng)項
這篇文章主要介紹了JS根據(jù)條件取出數(shù)組中對應(yīng)項,本文通過實例代碼給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下2023-03-03js以分隔符分隔數(shù)組中的元素并轉(zhuǎn)換為字符串的方法
下面小編就為大家?guī)硪黄猨s以分隔符分隔數(shù)組中的元素并轉(zhuǎn)換為字符串的方法。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2016-11-11