關於JavaScript中call()和apply() 的一些理解
關於JavaScript中call()和apply() 的一些理解
call()方法和apply()方法,在上層應用中用的不是很多,但在底層寫JS框架的時候卻常常看到。然後度娘谷哥一番,也發現好多達人寫出了自己的理解和筆記,但始終還是雲裏霧裏,於是去W3C學習了下
在W3C網上研究這兩個方法的時候,看到一個詞語,叫“對象冒充”,這個概念本人覺得還是挺重要的,讓我對這兩個方法理解起來更加直觀。
call()方法,看下官方給出的例子
function sayColor(sPrefix,sSuffix) { alert(sPrefix + r + sSuffix);};var obj = new Object();r = "blue";(obj, "The color is ", "a very nice color indeed.");
最後輸出的結果是“The color is blue, a very nice color indeed.”
call()方法就是將第一個參數替換方法中的this,然後後面的參數傳入該方法使用
apply()方法,同樣先看個官方給出的例子
function sayColor(sPrefix,sSuffix) { alert(sPrefix + r + sSuffix);};var obj = new Object();r = "blue";y(obj, new Array("The color is ", "a very nice color indeed."));
最後輸出的`結果仍然是“The color is blue, a very nice color indeed.”
其實call()方法和apply()方法可以粗略的認為是差不多的,第一個參數都是替換方法中this關鍵字,只是後面傳給方法的傳參方式不同,call是直接對應,apply是利用數組,在數組中一一對應
-
淺析JavaScript基本類型與引用類型
兩種類型:ECMAScript變量包含兩種不同類型的值:基本類型值、引用類型值;基本類型值:指的是保存在棧內存中的簡單數據段;引用類型值:指的是那些保存在堆內存中的`對象,意思是,變量中保存的實際上只是一個指針,這個指針指向內存中的另一個位置,由該位置保存對象;兩種訪問方...
-
javascript操作select元素案例分析
本文實例講述了javascript操作select元素的.用法。分享給大家供大家參考。具體分析如下:這裏熟悉一下js對select元素的操作,html頁面中建立一個form,其中包含一個select元素和submit按鈕。當選擇select中某一項時改變其文字,當select中所有項的文字都改變後,重新恢...
-
如何理解Javascript的caller,callee,call,apply區別
在提到上述的概念之前,首先想説説javascript中函數的隱含參數:argumentsarguments該對象代表正在執行的函數和調用它的函數的參數。[function.]arguments[n]參數function:選項。當前正在執行的Function對象的名字。n:選項。要傳遞給Function對象的從0開始的參數值...
-
JavaScript基本語法分析
一、JavaScript基本語法。(一)數據類型與變量類型。整數,小數,佈局,字符串,日期時間,數組強制轉換:parseInt()parseFloat()isNaN()(二)數組var數組名=newArray([長度]);//“假冒”數組th-長度a[下標]=值。a[下標](三)函數複製代碼代碼如下:function函數名(形參){}function...
相關文章
- 如何理解Javascript的caller,callee,call,apply區別
- 如何理解Javascript的caller,callee,call,apply區別
- 關於javascript中apply()和call()方法的區別
- 如何理解Javascript的caller,callee,call,apply區別
- 如何理解Javascript的caller,callee,call,apply區別
- 如何理解Javascript的caller,callee,call,apply區別
- 如何理解Javascript的caller,callee,call,apply區別
- 如何理解Javascript的caller,callee,call,apply區別
- 如何理解Javascript的caller,callee,call,apply區別
- 如何理解Javascript的caller,callee,call,apply區別