亚洲中字慕日产2020,大陆极品少妇内射AAAAAA,无码av大香线蕉伊人久久,久久精品国产亚洲av麻豆网站

資訊專欄INFORMATION COLUMN

js函數(shù)那點事

nanchen2251 / 1178人閱讀

摘要:在種函數(shù)實際上是對象,每個函數(shù)都是類型的實例。也就是說一個函數(shù)可能會有多個名字。這就是我們平時所說的函數(shù)聲明提升。函數(shù)的內(nèi)部屬性包括具體不再敘述了函數(shù)的屬性和方法函數(shù)有個屬性,和表示函數(shù)希望接收命名參數(shù)的個數(shù)。

要知道,在js中,引用類型是一種數(shù)據(jù)結(jié)構(gòu),包含5種引用類型,分別是Object,data,Array,re請輸入代碼gExp,Function。今天我們就說Function這種數(shù)據(jù)結(jié)構(gòu)。
在js種函數(shù)實際上是對象,每個函數(shù)都是Function類型的實例。和其他引用類型一樣,都具有屬性和方法。
1. 函數(shù)定義有幾種方法

函數(shù)聲明語法定義

    function sum(num1,num2){
   return num1+num2;
  }

函數(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")

當然第三種方法不友好,也不推薦。

函數(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來擴充作用域最大的好處就是對象不和任何方法耦合

文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。

轉(zhuǎn)載請注明本文地址:http://www.ezyhdfw.cn/yun/92952.html

相關(guān)文章

  • 關(guān)于性能優(yōu)化的點事——函數(shù)防抖

    摘要:函數(shù)防抖場景假設(shè)網(wǎng)站有個搜索框用戶輸入文本我們會自動聯(lián)想匹配出一些結(jié)果供用戶選擇我們可能首先想到的做法就是監(jiān)聽事件然后異步查詢結(jié)果但是如果用戶快速的輸入了一串字符假設(shè)是個字符那么就會在瞬間觸發(fā)次請求這無疑不是我們想要的我們想要的是用戶停止輸 函數(shù)防抖 場景 假設(shè)網(wǎng)站有個搜索框, 用戶輸入文本我們會自動聯(lián)想匹配出一些結(jié)果供用戶選擇,我們可能首先想到的做法就是監(jiān)聽keypress事件, 然...

    Stardustsky 評論0 收藏0
  • 關(guān)于性能優(yōu)化的點事——函數(shù)節(jié)流

    摘要:函數(shù)節(jié)流背景中的函數(shù)大多數(shù)情況下都是由用戶主動調(diào)用觸發(fā)的除非是函數(shù)本身的實現(xiàn)不合理否則一般不會遇到跟性能相關(guān)的問題但在少數(shù)情況下函數(shù)的觸發(fā)不是由用戶直接控制的在這些場景下函數(shù)可能被非常頻繁調(diào)用而造成大的性能問題場景事件事件滾動事件共同的特征 函數(shù)節(jié)流 背景 javascript中的函數(shù)大多數(shù)情況下都是由用戶主動調(diào)用觸發(fā)的, 除非是函數(shù)本身的實現(xiàn)不合理, 否則一般不會遇到跟性能相關(guān)的問題...

    khlbat 評論0 收藏0
  • promise、async和await之執(zhí)行順序的點事

    摘要:是這樣描述的函數(shù)中可能會有表達式,這會使函數(shù)暫停執(zhí)行,等待表達式中的解析完成后繼續(xù)執(zhí)行函數(shù)并返回解決結(jié)果。返回值返回對象的處理結(jié)果。當執(zhí)行到時,這個任務(wù)會被放入到回調(diào)隊列中,等待調(diào)用棧有空閑時事件循環(huán)再來取走它。 原文地址:https://lvdingjin.github.io/tech/2018/05/27/async-and-await.html 故事要從一道今日頭條的筆試題說起...

    高勝山 評論0 收藏0
  • pjax不再神秘,hash、state點事

    摘要:初步理解如果最近打電話給武漢的小伙伴,他說信號不好,那么相信我,他肯定不是真的信號不好,也不是不想和你說話,而是他可能在冰箱里。。。 初步理解 如果最近打電話給武漢的小伙伴,他說信號不好,那么相信我,他肯定不是真的信號不好,也不是不想和你說話,而是他可能在冰箱里。。。武漢的天氣從來都是喜怒無常的,是吧,屌絲氣十足,今年也是絲毫看不出有任何逆襲的跡象和可能性,當然咱也沒必要去操那個心;好...

    solocoder 評論0 收藏0
  • 郵件發(fā)送點事

    摘要:配置在中,修改為,這樣的函數(shù)就可以發(fā)出正常的郵件了。沒找到哪兒改,所以我就直接用發(fā)送了。同時,郵件發(fā)送是一個耗時操作,不應(yīng)該讓進程長時間等待。相對復雜一些,它會對郵件內(nèi)容進行簽名,然后收件服務(wù)器通過獲取公鑰,核對簽名是否正確。 搭建Postfix 操作系統(tǒng)我個人比較喜歡CentOs,原生的系統(tǒng)都裝有,沒有的話 可以自己谷歌,這個很簡單 ,跳過。需要注意的是,Postfix默認只對本地I...

    acrazing 評論0 收藏0

發(fā)表評論

0條評論

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