這篇文章將為大家詳細(xì)講解有關(guān)js函數(shù)相關(guān)知識點(diǎn)有哪些,小編覺得挺實(shí)用的,因此分享給大家做個參考,希望大家閱讀完這篇文章后可以有所收獲。

創(chuàng)新互聯(lián)專注于高淳網(wǎng)站建設(shè)服務(wù)及定制,我們擁有豐富的企業(yè)做網(wǎng)站經(jīng)驗(yàn)。 熱誠為您提供高淳營銷型網(wǎng)站建設(shè),高淳網(wǎng)站制作、高淳網(wǎng)頁設(shè)計(jì)、高淳網(wǎng)站官網(wǎng)定制、重慶小程序開發(fā)服務(wù),打造高淳網(wǎng)絡(luò)公司原創(chuàng)品牌,更為您提供高淳網(wǎng)站排名全網(wǎng)營銷落地服務(wù)。
在js種函數(shù)實(shí)際上是對象,每個函數(shù)都是Function類型的實(shí)例。和其他引用類型一樣,都具有屬性和方法。
1. 函數(shù)定義有幾種方法
1)函數(shù)聲明語法定義
function sum(num1,num2){
return num1+num2;
}2)函數(shù)表達(dá)式
注意函數(shù)表達(dá)式后邊有一個分號;
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ù)表達(dá)式有什么區(qū)別呢?
解析器在向執(zhí)行環(huán)境中加載數(shù)據(jù)的時候,對函數(shù)聲明和函數(shù)表達(dá)式是不一樣的。解析器首先會讀取函數(shù)聲明,并且使得這段函數(shù)聲明代碼在任何代碼之前都可調(diào)用。這就是我們平時所說的函數(shù)聲明提升。函數(shù)表達(dá)式不一樣,他必須等到函數(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í)行器就會報(bào)錯!2.函數(shù)沒有重載
如果聲明了2個同名函數(shù),結(jié)果是后面的函數(shù)覆蓋了前面的函數(shù)。
function sun(a){
return a+100;
}
function sun(a){
return a+200;
}
var result=sum(2)//2023.函數(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 //0prototype屬性對于引用類型來說很重要,會有專門講解,此處不再這贅述。
每個函數(shù)都包含2個非繼承的方法 apply,call
這兩個方法的用途都是在特定的作用域中調(diào)用函數(shù),其實(shí)就是設(shè)置函數(shù)體內(nèi)的this指代的值。
首先。apply()方法接收2個參數(shù),一個是函數(shù)運(yùn)行的作用域,另一個是參數(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)) //2call方法和apply方法沒有多大的區(qū)別。區(qū)別就是call方法的第二個參數(shù)必須得傳遞的參數(shù)一個個列舉出來。
使用call和apply來擴(kuò)充作用域最大的好處就是對象不和任何方法耦合
關(guān)于“js函數(shù)相關(guān)知識點(diǎn)有哪些”這篇文章就分享到這里了,希望以上內(nèi)容可以對大家有一定的幫助,使各位可以學(xué)到更多知識,如果覺得文章不錯,請把它分享出去讓更多的人看到。
本文標(biāo)題:js函數(shù)相關(guān)知識點(diǎn)有哪些
鏈接地址:http://chinadenli.net/article48/gosghp.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供標(biāo)簽優(yōu)化、微信小程序、移動網(wǎng)站建設(shè)、品牌網(wǎng)站設(shè)計(jì)、App開發(fā)、ChatGPT
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)
猜你還喜歡下面的內(nèi)容