在這里函數聲明和函數表達式有什么區別呢?
解析器在向執行環境中加載數據的時候,對函數聲明和函數表達式是不一樣的。解析器首先會讀取函數聲明,并且使得這段函數聲明代碼在任何代碼之前都可調用。這就是我們平時所說的函數聲明提升。函數表達式不一樣,他必須等到函數解析器執行到他所在的代碼塊的時候,才會被真正的執行。比較下面2個例子
console.log(sum(10,10)); function sum(n1,n2){ return n1+n2; } 以上代碼會正常執行 再看! console.log(sum(10,10)); var sum=function(n1,n2){ return n1+n2; } 以上執行器就會報錯!
如果聲明了2個同名函數,結果是后面的函數覆蓋了前面的函數。
function sun(a){ return a+100; } function sun(a){ return a+200; } var result=sum(2)//202
包括this,arguments
具體不再敘述了
函數有2個屬性,length和prototype
length表示函數希望接收命名參數的個數。
function a(name){ //todo } function b(name,age){ //todo } function c(){ //todo } a.length //1 b.length //2 c.length //0
prototype屬性對于引用類型來說很重要,會有專門講解,此處不再這贅述。
每個函數都包含2個非繼承的方法 apply,call
這兩個方法的用途都是在特定的作用域中調用函數,其實就是設置函數體內的this指代的值。
首先。apply()方法接收2個參數,一個是函數運行的作用域,另一個是參數數組,第二個參數可以是數組的實例,也可以是arguments.
function sum(num1,num2){ return num1+num2; } function test1(a,b){ return sum.apply(this,arguments); } function test2(c,d){ return sum.apply(this.[c,d]); } console.log(test1(1,1)) //2 console.log(test2(1,1)) //2
call方法和apply方法沒有多大的區別。區別就是call方法的第二個參數必須得傳遞的參數一個個列舉出來。
使用call和apply來擴充作用域最大的好處就是對象不和任何方法耦合。
相關推薦:
JS函數實例詳解
js函數的按值傳遞參數
js函數的調用及有關隱式參數arguments和this的問題
聲明:本網頁內容旨在傳播知識,若有侵權等問題請及時與本網聯系,我們將在第一時間刪除處理。TEL:177 7030 7066 E-MAIL:11247931@qq.com