日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 前端技术 > javascript >内容正文

javascript

JS中的call()和apply()方法(转)

發布時間:2024/7/19 javascript 29 豆豆
生活随笔 收集整理的這篇文章主要介紹了 JS中的call()和apply()方法(转) 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

轉自:http://uule.iteye.com/blog/1158829

JS中的call()和apply()方法

博客分類:
  • ?
  • JS

1、方法定義

call方法:?
語法:call([thisObj[,arg1[, arg2[,?? [,.argN]]]]])?
定義:調用一個對象的一個方法,以另一個對象替換當前對象。?
說明:?
call 方法可以用來代替另一個對象調用一個方法。call 方法可將一個函數的對象上下文從初始的上下文改變為由 thisObj 指定的新對象。?
如果沒有提供 thisObj 參數,那么 Global 對象被用作 thisObj。?

apply方法:?
語法:apply([thisObj[,argArray]])?
定義:應用某一對象的一個方法,用另一個對象替換當前對象。?
說明:?
如果 argArray 不是一個有效的數組或者不是 arguments 對象,那么將導致一個 TypeError。?
如果沒有提供 argArray 和 thisObj 任何一個參數,那么 Global 對象將被用作 thisObj, 并且無法被傳遞任何參數。

?

2、常用實例

a、

Java代碼??
  • function?add(a,b)??
  • {??
  • ????alert(a+b);??
  • }??
  • function?sub(a,b)??
  • {??
  • ????alert(a-b);??
  • }??
  • ??
  • add.call(sub,3,1);???
  • ?這個例子中的意思就是用 add 來替換 sub,add.call(sub,3,1) == add(3,1) ,所以運行結果為:alert(4); // 注意:js 中的函數其實是對象,函數名是對 Function 對象的引用。

    ?

    b、

    Java代碼??
  • function?Animal(){????
  • ????this.name?=?"Animal";????
  • ????this.showName?=?function(){????
  • ????????alert(this.name);????
  • ????}????
  • }????
  • ??
  • function?Cat(){????
  • ????this.name?=?"Cat";????
  • }????
  • ???
  • var?animal?=?new?Animal();????
  • var?cat?=?new?Cat();????
  • ????
  • //通過call或apply方法,將原本屬于Animal對象的showName()方法交給對象cat來使用了。????
  • //輸入結果為"Cat"????
  • animal.showName.call(cat,",");????
  • //animal.showName.apply(cat,[]);??
  • ?call 的意思是把 animal 的方法放到cat上執行,原來cat是沒有showName() 方法,現在是把animal 的showName()方法放到 cat上來執行,所以this.name 應該是 Cat

    ?

    c、實現繼承

    Java代碼??
  • function?Animal(name){??????
  • ????this.name?=?name;??????
  • ????this.showName?=?function(){??????
  • ????????alert(this.name);??????
  • ????}??????
  • }??????
  • ????
  • function?Cat(name){????
  • ????Animal.call(this,?name);????
  • }??????
  • ????
  • var?cat?=?new?Cat("Black?Cat");?????
  • cat.showName();??
  • ?Animal.call(this) 的意思就是使用 Animal對象代替this對象,那么 Cat中不就有Animal的所有屬性和方法了嗎,Cat對象就能夠直接調用Animal的方法以及屬性了.

    ?

    d、多重繼承

    Java代碼??
  • function?Class10()??
  • {??
  • ????this.showSub?=?function(a,b)??
  • ????{??
  • ????????alert(a-b);??
  • ????}??
  • }??
  • ??
  • function?Class11()??
  • {??
  • ????this.showAdd?=?function(a,b)??
  • ????{??
  • ????????alert(a+b);??
  • ????}??
  • }??
  • ??
  • function?Class2()??
  • {??
  • ????Class10.call(this);??
  • ????Class11.call(this);??
  • }??
  • ?很簡單,使用兩個 call 就實現多重繼承了
    當然,js的繼承還有其他方法,例如使用原型鏈,這個不屬于本文的范疇,只是在此說明call 的用法。說了call ,當然還有 apply,這兩個方法基本上是一個意思,區別在于 call 的第二個參數可以是任意類型,而apply的第二個參數必須是數組,也可以是arguments
    還有 callee,caller..

    ?

    例子來源:http://xiaofeizm55333.iteye.com/blog/80913

    http://www.iteye.com/topic/599108?? 及回復..

    轉載于:https://www.cnblogs.com/weizhxa/p/6484060.html

    總結

    以上是生活随笔為你收集整理的JS中的call()和apply()方法(转)的全部內容,希望文章能夠幫你解決所遇到的問題。

    如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。