久久久久无码精品,四川省少妇一级毛片,老老熟妇xxxxhd,人妻无码少妇一区二区

JavaScript中call()和apply() 的一些理解

時間:2024-09-16 17:00:20 JavaScript 我要投稿
  • 相關(guān)推薦

關(guān)于JavaScript中call()和apply() 的一些理解

  關(guān)于JavaScript中call()和apply() 的一些理解

  call()方法和apply()方法,在上層應(yīng)用中用的不是很多,但在底層寫JS框架的時候卻常?吹。然后度娘谷哥一番,也發(fā)現(xiàn)好多達人寫出了自己的理解和筆記,但始終還是云里霧里,于是去W3C學(xué)習(xí)了下

  在W3C網(wǎng)上研究這兩個方法的時候,看到一個詞語,叫“對象冒充”,這個概念本人覺得還是挺重要的,讓我對這兩個方法理解起來更加直觀。

  call()方法,看下官方給出的例子

  function sayColor(sPrefix,sSuffix) { alert(sPrefix + this.color + sSuffix);};var obj = new Object();obj.color = "blue";sayColor.call(obj, "The color is ", "a very nice color indeed.");

  最后輸出的結(jié)果是“The color is blue, a very nice color indeed.”

  call()方法就是將第一個參數(shù)替換方法中的this,然后后面的參數(shù)傳入該方法使用

  apply()方法,同樣先看個官方給出的例子

  function sayColor(sPrefix,sSuffix) { alert(sPrefix + this.color + sSuffix);};var obj = new Object();obj.color = "blue";sayColor.apply(obj, new Array("The color is ", "a very nice color indeed."));

  最后輸出的結(jié)果仍然是“The color is blue, a very nice color indeed.”

  其實call()方法和apply()方法可以粗略的認為是差不多的,第一個參數(shù)都是替換方法中this關(guān)鍵字,只是后面?zhèn)鹘o方法的傳參方式不同,call是直接對應(yīng),apply是利用數(shù)組,在數(shù)組中一一對應(yīng)

  

【JavaScript中call()和apply() 的一些理解】相關(guān)文章:

對javascript的理解08-08

淺談javascript中的單線程理解08-16

有關(guān)深入理解JavaScript中的并行處理的介紹10-14

理解JavaScript原型鏈教程09-02

javascript的閉包概念怎么理解06-15

Javascript中arguments對象的詳解和使用方法08-20

JavaScript中的with關(guān)鍵字07-24

在Java中執(zhí)行JavaScript代碼07-14

Javascript中typeof 用法歸納09-27