您好,登錄后才能下訂單哦!
這篇文章將為大家詳細(xì)講解有關(guān)js函數(shù)相關(guān)知識點有哪些,小編覺得挺實用的,因此分享給大家做個參考,希望大家閱讀完這篇文章后可以有所收獲。
在js種函數(shù)實際上是對象,每個函數(shù)都是Function類型的實例。和其他引用類型一樣,都具有屬性和方法。
1. 函數(shù)定義有幾種方法
1)函數(shù)聲明語法定義
function sum(num1,num2){ return num1+num2; }
2)函數(shù)表達式
注意函數(shù)表達式后邊有一個分號;
var sum=function(num1,num2){ return num1+num2; }
使用Function 構(gòu)造函數(shù)
使用構(gòu)造函數(shù)可以接收任意數(shù)量的參數(shù),但最后一個參數(shù)始終被看成是函數(shù)體,而前面的參數(shù)則枚舉出了參數(shù)
var sum=new Function("num1","num2","return num1+num2")
當(dāng)然第三種方法不友好,也不推薦。
函數(shù)名僅僅是指向函數(shù)的指針,所以函數(shù)名與包含對象指針的其他變量沒有什么不同。也就是說一個函數(shù)可能會有多個名字。
在這里函數(shù)聲明和函數(shù)表達式有什么區(qū)別呢?
解析器在向執(zhí)行環(huán)境中加載數(shù)據(jù)的時候,對函數(shù)聲明和函數(shù)表達式是不一樣的。解析器首先會讀取函數(shù)聲明,并且使得這段函數(shù)聲明代碼在任何代碼之前都可調(diào)用。這就是我們平時所說的函數(shù)聲明提升。函數(shù)表達式不一樣,他必須等到函數(shù)解析器執(zhí)行到他所在的代碼塊的時候,才會被真正的執(zhí)行。比較下面2個例子
console.log(sum(10,10)); function sum(n1,n2){ return n1+n2; } 以上代碼會正常執(zhí)行 再看! console.log(sum(10,10)); var sum=function(n1,n2){ return n1+n2; } 以上執(zhí)行器就會報錯!
2.函數(shù)沒有重載
如果聲明了2個同名函數(shù),結(jié)果是后面的函數(shù)覆蓋了前面的函數(shù)。
function sun(a){ return a+100; } function sun(a){ return a+200; } var result=sum(2)//202
3.函數(shù)的內(nèi)部屬性
包括this,arguments
具體不再敘述了
4.函數(shù)的屬性和方法
函數(shù)有2個屬性,length和prototype
length表示函數(shù)希望接收命名參數(shù)的個數(shù)。
function a(name){ //todo } function b(name,age){ //todo } function c(){ //todo } a.length //1 b.length //2 c.length //0
prototype屬性對于引用類型來說很重要,會有專門講解,此處不再這贅述。
每個函數(shù)都包含2個非繼承的方法 apply,call
這兩個方法的用途都是在特定的作用域中調(diào)用函數(shù),其實就是設(shè)置函數(shù)體內(nèi)的this指代的值。
首先。apply()方法接收2個參數(shù),一個是函數(shù)運行的作用域,另一個是參數(shù)數(shù)組,第二個參數(shù)可以是數(shù)組的實例,也可以是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方法沒有多大的區(qū)別。區(qū)別就是call方法的第二個參數(shù)必須得傳遞的參數(shù)一個個列舉出來。
使用call和apply來擴充作用域最大的好處就是對象不和任何方法耦合
關(guān)于“js函數(shù)相關(guān)知識點有哪些”這篇文章就分享到這里了,希望以上內(nèi)容可以對大家有一定的幫助,使各位可以學(xué)到更多知識,如果覺得文章不錯,請把它分享出去讓更多的人看到。
免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關(guān)證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。