欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

一道優(yōu)雅面試題分析js中fn()和return fn()的區(qū)別

 更新時(shí)間:2016年07月05日 16:22:30   作者:饒總真壞  
這篇文章主要帶領(lǐng)大家深入理解JavaScript中 fn() 和 return fn() 的區(qū)別,感興趣的小伙伴們可以參考一下

在js中,經(jīng)常會(huì)遇到在函數(shù)里調(diào)用其它函數(shù)的情況,這時(shí)候會(huì)有 fn() 這種調(diào)用方式,還有一種是 return fn() 這種調(diào)用方式,一些初學(xué)者經(jīng)常會(huì)被這兩種方式給繞暈了。這里用一個(gè)優(yōu)雅的面試題來(lái)分析一下兩種方式的不同之處。 

var i = 0;
function fn(){
 i++;
 if(i < 10){
 fn();
 }else{
 return i;
 }
}

var result = fn();
console.log(result); 

這是一道隱藏了坑的面試題,看似很簡(jiǎn)單,大部分人可能想都不想就答出了10。而實(shí)際上運(yùn)行可知打印出來(lái)的是 undefined。這道陷阱題很直觀的體現(xiàn)出了前面所說(shuō)的問(wè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); 

這時(shí),會(huì)發(fā)現(xiàn)打印出來(lái)的結(jié)果終于不負(fù)眾望的是 10 了。

為什么這里加不加return區(qū)別會(huì)這么大? 

這里的主要原因很簡(jiǎn)單,JavaScript的函數(shù)都是有默認(rèn)返回值的,如果函數(shù)結(jié)尾不寫(xiě)return,會(huì)默認(rèn)返回undefined,這就是為什么在chrome的console控制臺(tái)里,寫(xiě)代碼經(jīng)常下面會(huì)出現(xiàn)一行undefined的原因。 

再仔細(xì)看看這個(gè)例子,當(dāng)i自增到9的時(shí)候,也就是倒數(shù)第二次遞歸調(diào)用fn的那一次,如果沒(méi)有return,這一次執(zhí)行完fn,會(huì)默認(rèn)return undefined,而不會(huì)繼續(xù)下一次遞歸了。當(dāng)加上了 return,在這里則會(huì)繼續(xù)最后一次遞歸,即i=10的時(shí)候,跳入else里面返回得到正確的10。 

說(shuō)到這里,可以引申出一個(gè)更為經(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)用,很多新手在第一次實(shí)現(xiàn)這個(gè)算法的時(shí)候經(jīng)常會(huì)犯的一個(gè)錯(cuò)誤就是忘記在遞歸的函數(shù)前加上return,最后導(dǎo)致返回結(jié)果是undefined,這里的道理也和前面是類似的,不加return,會(huì)導(dǎo)致遞歸后,直接返回undefined,不會(huì)繼續(xù)下一次遞歸。

以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。

相關(guān)文章

  • 利用JS實(shí)現(xiàn)點(diǎn)擊按鈕后圖片自動(dòng)切換的簡(jiǎn)單方法

    利用JS實(shí)現(xiàn)點(diǎn)擊按鈕后圖片自動(dòng)切換的簡(jiǎn)單方法

    下面小編就為大家?guī)?lái)一篇利用JS實(shí)現(xiàn)點(diǎn)擊按鈕后圖片自動(dòng)切換的簡(jiǎn)單方法。小編覺(jué)得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧
    2016-10-10
  • JS正則替換掉小括號(hào)及內(nèi)容的方法

    JS正則替換掉小括號(hào)及內(nèi)容的方法

    下面小編就為大家?guī)?lái)一篇JS正則替換掉小括號(hào)及內(nèi)容的方法。小編覺(jué)得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧
    2016-11-11
  • 手寫(xiě)Spirit防抖函數(shù)underscore和節(jié)流函數(shù)lodash

    手寫(xiě)Spirit防抖函數(shù)underscore和節(jié)流函數(shù)lodash

    這篇文章主要介紹了手寫(xiě)Spirit防抖函數(shù)underscore和節(jié)流函數(shù)lodash,接下來(lái)將會(huì)帶你們了解下這兩者的區(qū)別,以及我們?cè)撊绾问謱?xiě)實(shí)現(xiàn)這兩個(gè)函數(shù)
    2022-03-03
  • JavaScript 拖拉時(shí)間之drag案例詳解

    JavaScript 拖拉時(shí)間之drag案例詳解

    這篇文章主要介紹了JavaScript 拖拉時(shí)間之drag案例詳解,本篇文章通過(guò)簡(jiǎn)要的案例,講解了該項(xiàng)技術(shù)的了解與使用,以下就是詳細(xì)內(nèi)容,需要的朋友可以參考下
    2021-09-09
  • Textbox控件注冊(cè)回車事件及觸發(fā)按鈕提交事件具體實(shí)現(xiàn)

    Textbox控件注冊(cè)回車事件及觸發(fā)按鈕提交事件具體實(shí)現(xiàn)

    Lyncplus客戶端中訪問(wèn)Web頁(yè)面時(shí)遇到了TextBox控件回車自動(dòng)完成按鈕的提交事件失效的情況,于是上網(wǎng)查找相關(guān)的介紹最終解決了這兩個(gè)問(wèn)題,感興趣的你可以參考下或許對(duì)你有所幫助
    2013-03-03
  • JS如何根據(jù)條件取出數(shù)組中對(duì)應(yīng)項(xiàng)

    JS如何根據(jù)條件取出數(shù)組中對(duì)應(yīng)項(xiàng)

    這篇文章主要介紹了JS根據(jù)條件取出數(shù)組中對(duì)應(yīng)項(xiàng),本文通過(guò)實(shí)例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2023-03-03
  • js移動(dòng)焦點(diǎn)到最后位置的簡(jiǎn)單方法

    js移動(dòng)焦點(diǎn)到最后位置的簡(jiǎn)單方法

    下面小編就為大家?guī)?lái)一篇js移動(dòng)焦點(diǎn)到最后位置的簡(jiǎn)單方法。小編覺(jué)得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧
    2016-11-11
  • uniapp H5 https跨域請(qǐng)求實(shí)現(xiàn)

    uniapp H5 https跨域請(qǐng)求實(shí)現(xiàn)

    這篇文章主要介紹了uniapp H5 https跨域請(qǐng)求實(shí)現(xiàn),文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2021-01-01
  • js以分隔符分隔數(shù)組中的元素并轉(zhuǎn)換為字符串的方法

    js以分隔符分隔數(shù)組中的元素并轉(zhuǎn)換為字符串的方法

    下面小編就為大家?guī)?lái)一篇js以分隔符分隔數(shù)組中的元素并轉(zhuǎn)換為字符串的方法。小編覺(jué)得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧
    2016-11-11
  • js如何在字符串中查找某個(gè)字符的位置

    js如何在字符串中查找某個(gè)字符的位置

    這篇文章主要給大家介紹了關(guān)于js如何在字符串中查找某個(gè)字符的位置的相關(guān)資料,在JavaScript中我們經(jīng)常需要對(duì)字符串進(jìn)行各種操作,包括查找包含特定字符的字符串,需要的朋友可以參考下
    2023-11-11

最新評(píng)論