javascript的函數定義的區別


      javascript中函數定義通常有兩種方法:

      1. 普通的函數定義:

function f1 (){}

  2. 變量式函數定義:

var f2 = function(){}

     還有一種定義方法是new Function,由於這種方法並不常用,這里就不做解釋了。

     那這兩種定義方法有什么不同呢?難道僅僅只是樣子不同而已嘛?當然不是這樣,我們來看個具體的例子吧,大家覺得以下代碼的執行結果是什么?

if (1 === 1) {
tellAlert();
} else{
function tellAlert(){
alert('hello');
}
}

     執行結果是:會提示“hello”
     那接下來這段代碼呢?

if (1 === 1) {
tellAlert();
} else{
var tellAlert = function (){
alert('hello');
}
}

     執行結果是:游覽器不會提示“hello”,chrome中的控制台還會報錯:

    

    從上例中,我們可以明顯看出,兩者很大的不同就是執行順序不同,這是function語句在解析時會發生被提升的情況。也就是說不管function被放置在哪里,它都會被移動到被定義時所在作用域的頂層。這樣的后果就是放寬了函數必須先聲明后使用的要求。

   《javascript語言精粹》中推薦使用的方法是 var f1 = function()。這樣能明確表示f1 是一個包含一個函數值的變量。

     而nodejs的源碼中,定義函數的方法是function f1()。

     個人感覺,在控制自己的代碼邏輯的基礎上,直接用function f1()會更好點,代碼會更清楚點。


·


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM