欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

js中apply與call簡單用法詳解

 更新時間:2017年11月06日 10:47:12   作者:曾田生z  
這篇文章主要為大家詳細介紹了js中apply與call簡單用法,具有一定的參考價值,感興趣的小伙伴們可以參考一下

你可以直接看例子,也可以先讀一下介紹:

call和apply是為了動態(tài)改變this而出現(xiàn)的,當一個object沒有某個方法,但是其他的有,我們可以借助call或apply用其它對象的方法來操作。

call, apply都屬于Function.prototype的一個方法,它是JavaScript引擎內(nèi)在實現(xiàn)的,因為屬于Function.prototype,所以每個Function對象實例,也就是每個方法都有call, apply屬性.既然作為方法的屬性,那它們的使用就當然是針對方法的了.這兩個方法是容易混淆的,因為它們的作用一樣,只是使用方式不同.
從上面可以得出 call, apply 是給方法使用的,為了改變調(diào)用該方法的 this指針

簡單例子:

call

function A() {
  this.getName = function (xx) {
    return xx;
  }
}

function B() {

}

var a = new A();
console.log( a.getName('i am A') ); //i am A

var b = new B() ;
console.log( a.getName.call(b,'i am B') ); // i am B

B 函數(shù)中沒有 任何方法 , A 函數(shù)有個 getName() 方法 ,a.getName() 自然成立 ,但 B 也要使用 getName() 的方法怎么辦呢 ? 那就用 call(this,'參數(shù)') ??!

可以 再理解一下這句話 -- 我們可以借助call或apply調(diào)用其它對象的方法來操作,call和apply是為了動態(tài)改變this而出現(xiàn)的 ,本來 a.getName() 的 this 指向 a, call 動態(tài)的 把 this 指向了 b ,變成了 b.getName()

apply

apply 與 call 只是參數(shù)的使用不同而已

function A() {
  this.sun = function (a ,b) {
    return a+b;
  }
}

function B() {

}

var a = new A();
console.log( a.sun(1,2) ); //3

var b = new B() ;
console.log( a.sun.call(b,2,2) ); // 4

console.log( a.sun.apply(b,[3, 3]) ); //6

call和apply一般使用情況

用的比較多的,通過document.getElementsByTagName選擇的dom 節(jié)點是一種類似array的array。它不能應用Array下的push,pop等方法。我們可以通過:

var domNodes = Array.prototype.slice.call(document.getElementsByTagName("*"));

這樣domNodes就可以應用Array下的所有方法了。

以上就是本文的全部內(nèi)容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。

相關文章

  • JavaScript實現(xiàn)繪制兩個坐標之間的連線

    JavaScript實現(xiàn)繪制兩個坐標之間的連線

    本文主要介紹了JavaScript實現(xiàn)繪制兩個坐標之間的連線功能,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2023-11-11
  • js 多瀏覽器分別判斷代碼

    js 多瀏覽器分別判斷代碼

    比較實用的多款瀏覽器判斷代碼,需要的朋友可以收集下,適合需要區(qū)別對待不同瀏覽器,執(zhí)行不用的操作的代碼。
    2010-04-04
  • uniapp實現(xiàn)微信一鍵登錄按鈕樣式(膠囊按鈕的樣式)

    uniapp實現(xiàn)微信一鍵登錄按鈕樣式(膠囊按鈕的樣式)

    這篇文章主要介紹了uniapp實現(xiàn)微信一鍵登錄按鈕樣式,如何開發(fā)膠囊按鈕的樣式,需要的朋友可以參考下
    2024-07-07
  • 微信小程序?qū)崿F(xiàn)animation動畫

    微信小程序?qū)崿F(xiàn)animation動畫

    這篇文章主要為大家詳細介紹了微信小程序?qū)崿F(xiàn)animation動畫的方法,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2018-01-01
  • Bootstrap 實現(xiàn)表格樣式、表單布局的實例代碼

    Bootstrap 實現(xiàn)表格樣式、表單布局的實例代碼

    這篇文章主要介紹了Bootstrap 實現(xiàn)表格樣式、表單布局的實例代碼,需要的朋友可以參考下
    2018-12-12
  • Javascript閉包的作用與使用方法淺析

    Javascript閉包的作用與使用方法淺析

    閉包是js的一個難點也是它的一個特色,是我們必須掌握的js高級特性,下面這篇文章主要給大家介紹了關于JavaScript閉包函數(shù)的相關資料,需要的朋友可以參考下
    2023-01-01
  • JavaScript原生數(shù)組Array常用方法

    JavaScript原生數(shù)組Array常用方法

    在入門Vue時, 列表渲染一節(jié)中提到數(shù)組的變異方法, 其中包括push(), pop(), shift(), unshift(), splice(), sort(), reverse(), 而concat()和slice()不屬于變異方法. 在這里就復習一下Array所提供的這幾個方法的使用
    2017-04-04
  • 基于Electron實現(xiàn)桌面應用開發(fā)代碼實例

    基于Electron實現(xiàn)桌面應用開發(fā)代碼實例

    這篇文章主要介紹了基于Electron實現(xiàn)桌面應用開發(fā)代碼實例,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友可以參考下
    2020-07-07
  • 關于JS中的作用域中的問題思考分享

    關于JS中的作用域中的問題思考分享

    這篇文章主要介紹了關于JS中的作用域中的問題思考分享,scope和?closure是?javascript中兩個非常關鍵的概念,前者JS用多了還比較好理解而且容易體會到,而?closure就不一樣了。這玩意是真的很容易迷糊,需要的朋友可以參考下
    2022-04-04
  • JS正則表達式驗證密碼強度

    JS正則表達式驗證密碼強度

    這篇文章主要為大家詳細介紹了JS正則表達式驗證密碼強度,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2020-03-03

最新評論