国产xxxx99真实实拍_久久不雅视频_高清韩国a级特黄毛片_嗯老师别我我受不了了小说

資訊專欄INFORMATION COLUMN

譯: 函數提升與提升面試的相關問題

wuaiqiu / 2851人閱讀

摘要:函數提升在里有兩種方式創建函數,通過函數聲明和函數表達式。函數聲明用指定的參數來定義函數。提示不要在中進行函數聲明。問題輸出兩個都是用函數聲明的函數,將被提升到的局部作用域頂端。函數本身將作為函數聲明在全局范圍內提升。

作者關于提升的話題,總共有兩篇。(后來又有一個討論篇),再次搬過來。水平有限,如果翻譯的不準確請包涵,并去看原文。下面開始:

這是我之前的關于“提升”的文章,標題為《用let,const來指導你的JavaScript變量提升》(中/英)的第二部分。因此在深入研究之前,請確保你已經閱讀過第一部分。

之前我只討論過變量提升,是因為函數提升在JavaScript中與變量提升不同。它有自己的獨特方式。我將在這對函數進行擴展,以及在面試中面試官總會提問的“提升”(變量和函數)的棘手問題。

希望通過完成這兩部分,你能真的在你的JavaScript檢查清單中劃掉它。

讓我們開始吧。

函數提升

在JavaScript里有兩種方式創建函數,通過函數聲明函數表達式。那就看看這兩種方式是如何影響“提升”的。

函數聲明

用指定的參數來定義函數。
語法:

function name(param1, param2, ...) {
  [statements]
}

在JavaScript里,函數聲明提升函數定義。
因此,這些函數在被聲明之前便可以使用。
例子:

hoisted() // output: "Hoisted"

function hoisted() {
  console.log("Hoisted")
}

下面的例子,展示JavaScript編譯器如何看待上面的代碼:

// Hoisted code
function hoisted() {
  console.log("Hoisted")
}// Rest of the code
hoisted() // output: "Hoisted" 

如果你在全局作用域或者功能區作用域(在JavaScript里基本叫局部作用域)進行函數聲明,這個行為是真實的。
這非常有用,因為你能在代碼開頭使用高級邏輯,使其可讀與可理解。
提示:不要在“if/else”中進行函數聲明。

函數表達式

“function”關鍵字也能在一個表達式中定義一個函數。
語法:

const myFunction = function [name](param1, param2, ...) {
  [statements]
}

函數名是可選的,因此可以是匿名函數。我們可以用箭頭函數,如下所示:

const myFunction = (param1, param2, ...) => {
  [statements]
}

在JavaScript里,函數表達式沒有被提升。
因此,你不能使用函數表達式在定義它們之前。
例子:

notHoisted() // TypeError: notHoisted is not a function

const notHoisted = function() {
  console.log("foo")
}

關于函數創建中“提升”的部分,以上所有這些都要記住。
現在來看看面試問題!

“提升”面試問題

“提升”的不穩定行為一直是面試過程中的熱門問題。用之前和現在這兩篇文章的知識,可以解答這個話題中的任何問題。

問題 1 :
var a = 1;

function b() {
  a = 10;
  return;

  function a() {}
}

b();
console.log(a);

輸出: 1, 這是為什么?! ?
這是因為“function a() {}”聲明被創建在“函數/局部”作用域中。這個新“a”函數在聲明和定義的時候被提升到它的封閉函數b的頂端。下面演示發生了什么:

var a = 1;

function b() {
  // Hoisted
  function a() {}

  a = 10;
  return;
}

b();

console.log(a)

因此,賦值a=10;不能改變全局作用域a的值,任然是1,而是將局部a從函數改為整數10。
如果聲明函數a不在這,那將輸出10。

問題 2:
function foo(){
    function bar() {
        return 3;
    }
    return bar();
    function bar() {
        return 8;
    }
}
alert(foo());

輸出:8
兩個bar都是用函數聲明的函數,將被提升到foo的局部作用域頂端。

然而,返回8的bar()將晚于第一個返回3的提升。因此,這個返回8的函數將被執行。

之后的場景:

function foo(){
    //Hoisted before
    function bar() {
        return 3;
    }
    // Hoisted after
    function bar() {
        return 8;
    }    return bar();
    
}
alert(foo());
問題 3:
function parent() {
    var hoisted = "I"m a variable";
    function hoisted() {
        return "I"m a function";
    }
    return hoisted(); 
}
console.log(parent());

輸出:“類型錯誤:hoisted不是一個函數”
這個很詭異。函數 vs 變量!我們來分析下。
我們都知道,說到變量提升,只有聲明被提升(值是“undefined”),而不是定義!

如果是函數聲明的方式聲明函數,聲明和定義一并提升!
現在,如果是多個相同標識符聲明(變量和函數在同一作用域里)這樣的情況,這個變量的提升會直接忽略。

解釋器只聲明函數并提升它。

最終,這個聲明變量變量賦值被執行(沒有被提升),且值分配給了被提升的函數,值“I‘m a variable” ,

這是一個簡單的字符串而不是函數。于是報錯了!

這后面的場景重現了問題:

function parent() {    // Function declaration hoisted with the definition
    function hoisted() {
        return "I"m a function";
    }    // Declaration ignored, assignment of a string
    hoisted = "I"m a variable";
    return hoisted(); 
}
console.log(parent()); 
問題 4:
alert(foo());
function foo() {
  var bar = function() {
    return 3;
  };
  return bar();
  var bar = function() {
    return 8;
  };
}

輸出:3
這個簡單。函數foo()本身將作為函數聲明在全局范圍內提升。在函數foo里面,是兩個明確的函數表達式的例子。

編譯器不會提前讀取第二個函數bar() (沒有提升)。第一個將被執行并返回。

問題 5:
var myVar = "foo";(function() {
  console.log("Original value was: " + myVar);
  var myVar = "bar";
  console.log("New value is: " + myVar);
})();

輸出: “Original value was: undefined”, “New value is: bar”

在這個例子中,全局變量myVar的值‘foo’出現在picture之外。這是因為變量myVar在函數作用域內部聲明和定義,而且被提升到了IIFE的頂端,值是‘undefined’,他被首先記錄。然后將值“bar”分配并記錄下來。

這是我這里對JavaScript提升的總結。?

希望這兩篇(中/英)文章能對你有幫助。

如果你想學習箭頭函數和ES6其他相關的功能,請查看下面的文章。

Peace ??

至此,關于提升的兩篇文章結束了。后來一個讀者和作者就問題1問題3產生了分歧。到時候也搬過來吧。

文章版權歸作者所有,未經允許請勿轉載,若此文章存在違規行為,您可以聯系管理員刪除。

轉載請注明本文地址:http://specialneedsforspecialkids.com/yun/90452.html

相關文章

  • 】Javascript 面試完美指南(開發者視角)

    摘要:閉包是返回另一個函數并攜帶數據的函數。當程序的上下文和作用域發生變化時,也會發生相應的變化。之所以是類型,是因為類的構造函數它是類型的。如下這里的是一個回調函數,當成功響應請求時將執行該回調函數。 譯者:前端小智 原文:medium.com/dev-bits/a-… 想閱讀更多優質文章請猛戳GitHub博客,一年百來篇優質文章等著你! 為了說明 JS 面試的復雜性,首先,請嘗試給出以下結果...

    Joonas 評論0 收藏0
  • JavasScript重難點知識

    摘要:忍者級別的函數操作對于什么是匿名函數,這里就不做過多介紹了。我們需要知道的是,對于而言,匿名函數是一個很重要且具有邏輯性的特性。通常,匿名函數的使用情況是創建一個供以后使用的函數。 JS 中的遞歸 遞歸, 遞歸基礎, 斐波那契數列, 使用遞歸方式深拷貝, 自定義事件添加 這一次,徹底弄懂 JavaScript 執行機制 本文的目的就是要保證你徹底弄懂javascript的執行機制,如果...

    forsigner 評論0 收藏0
  • 你應該要知道作用域和閉包

    摘要:寫在前面對于一個前端開發者,應該沒有不知道作用域的。欺騙詞法作用域有兩個機制可以欺騙詞法作用域和。關于你不知道的的第一部分作用域和閉包已經結束了,但是,更新不會就此止住未完待續 這是《你不知道的JavaScript》的第一部分。 本系列持續更新中,Github 地址請查閱這里。 寫在前面 對于一個前端開發者,應該沒有不知道作用域的。它是一個既簡單有復雜的概念,簡單到每行代碼都有它的影子...

    JouyPub 評論0 收藏0
  • 前端優化 - 收藏集 - 掘金

    摘要:雖然有著各種各樣的不同,但是相同的是,他們前端優化不完全指南前端掘金篇幅可能有點長,我想先聊一聊閱讀的方式,我希望你閱讀的時候,能夠把我當作你的競爭對手,你的夢想是超越我。 如何提升頁面渲染效率 - 前端 - 掘金Web頁面的性能 我們每天都會瀏覽很多的Web頁面,使用很多基于Web的應用。這些站點看起來既不一樣,用途也都各有不同,有在線視頻,Social Media,新聞,郵件客戶端...

    VincentFF 評論0 收藏0

發表評論

0條評論

最新活動
閱讀需要支付1元查看
<