亚洲激情专区-91九色丨porny丨老师-久久久久久久女国产乱让韩-国产精品午夜小视频观看

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

call與apply函數怎么在JavaScript中使用

發布時間:2021-01-04 14:58:18 來源:億速云 閱讀:125 作者:Leah 欄目:web開發

call與apply函數怎么在JavaScript中使用?相信很多沒有經驗的人對此束手無策,為此本文總結了問題出現的原因和解決方法,通過這篇文章希望你能解決這個問題。

call 函數

語法

obj.call(thisObj,arg[,arg2[,arg3[,...agr]]]);

簡介

thisObj繼承obj的屬性和方法(obj原型鏈上的屬性和方法不能被繼承),后面的參數會當成obj的參數安裝順序傳遞進去。

示例

function animal(type,nickname){
    this.type = type;
    this.nickname = nickname;
    this.sayHello = function(){
      return 'hello';
    }
}
function cat(name,type,nickname){
    this.name = name;
    //cat繼承animal
    animal.call(this,type,nickname);
}
console.log(new cat('wsscat','cut','tom'));
/*
cat {
 name: 'wsscat',
 type: 'cut',
 nickname: 'tom',
 sayHello: [Function] }
*/

apply 函數

語法

obj.apply(this[,argArray]);

簡介

apply和call的作用差不多,都可以用來繼承,區別在與apply只有兩個參數,第二個參數必須是數組或者arguments對象。否則會報TypeError錯誤。如果繼承的對象obj有多個參數,則會吧argArray的參數依次對應obj的每個參數。

示例

function animal(type,nickname){
    this.type = type;
    this.nickname = nickname;
    this.syaHello = function(){
      return 'hello';
    }
}
function cat(name,type,nickname){
    this.name = name;
    animal.apply(this,arguments);
}
console.log(new cat('wsscat','cut','tom'));
/*
cat {
 name: 'wsscat',
 type: 'wsscat',
 nickname: 'cut',
 syaHello: [Function] }
*/

總結

callapply在功能是相同的。

相同點在于都是用于對象的繼承,第一個參數都是thisObj.

不同點在于call可以有多個參數,從第二個參數開始往后的參數會依次傳給被繼承的對象做參數。apply只有兩個參數,第二個參數必須是數組類型或者arguments對象類型,而且他會把數組中的元素依次傳遞給被繼承的對象做參數。

通過以上幾點,我們可以得到如果被繼承的對象只有一個參數的可以使用call,如果被繼承的對象有多個參數的,建議使用apply.

補充

js中可以實現多繼承,只需要調用多次call或apply即可。如:

function animal(type,nickname){
    this.type = type;
    this.nickname = nickname;
    this.syaHello = function(){
      return 'hello';
    }
}
function wscat(name,age){
    this.name = name;
    this.age = age;
    this.sayMe = function(){
      return 'my name:' + this.name + ', age:' + this.age;
    }
}
function cat(name,age,type,nickname){
    //第一種使用call
    animal.call(this,type,nickname);
    wscat.call(this,name,age);
    //第二種使用apply
    //animal.apply(this,[type,nickname]);
    //wscat.apply(this,[name,age]);
}
console.log(new cat('wscat',2,'cat','tom');
/*
cat {
 type: 'cat',
 nickname: 'tom',
 syaHello: [Function],
 name: 'wscat',
 age: 2,
 sayMe: [Function] }
*/

繼承的優化

如果構造函數this綁定了太多的屬性(比如一些共用的函數),示例化后就會照成浪費(因為this里的屬性和方法實例化后會復制一份給新對象,多個對象之間的屬性和方法互不干涉,對于一些可以共用的方法來就會造成浪費)

所以我們一般把共用的函數都放在原型鏈(prototype)上。但是使用call和apply無法繼承原型鏈上的屬性和方法。

因此我們可以使用混合的而寫法,使用原型鏈和(applycall)組合的方式進行繼承。

讓子的原型鏈指向父的示例(父的實例化對象)。如:

cat.prototype = new animal();

讓父的屬性創建在子的this上。如:

animal.call(this[,arg]);
//animal.apply(this[,argArray]);

具體代碼如下:

function animal(type,nickname){
    this.type = type;
    this.nickname = nickname;
}
animal.prototype.sayHello = function(){
    return 'hello';
}
function wscat(name,age){
    this.name = name;
    this.age = age;
} 
//這里是關鍵,原型鏈只能單繼承,
//不能同時繼承多個原型鏈,所以要一級一級來。
wscat.prototype = new animal();
wscat.prototype.sayMe = function(){
    return 'my name:' + this.name + ', age:' + this.age;
}
function cat(name,age,type,nickname){
    animal.call(this,type,nickname);
    wscat.call(this,name,age);
}
cat.prototype = new wscat();
var obj = new cat('wscat',10,'cat','tom');
console.log(obj);
//animal { type: 'cat', nickname: 'tom', name: 'wscat', age: 10 }
console.log(obj.sayHello());//hello
console.log(obj.sayMe());
/*
    my name:wscat, age:10
*/

看完上述內容,你們掌握call與apply函數怎么在JavaScript中使用的方法了嗎?如果還想學到更多技能或想了解更多相關內容,歡迎關注億速云行業資訊頻道,感謝各位的閱讀!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

庆城县| 汝阳县| 焉耆| 永登县| 唐海县| 台山市| 林西县| 虞城县| 河北区| 寿宁县| 犍为县| 墨江| 唐山市| 浦东新区| 庄浪县| 天镇县| 涟水县| 龙游县| 固始县| 海门市| 怀仁县| 呼图壁县| 天等县| 大城县| 华宁县| 江陵县| 黑水县| 日喀则市| 防城港市| 常州市| 剑河县| 浮梁县| 子长县| 洛隆县| 康保县| 安多县| 台南县| 平阴县| 阳春市| 聂拉木县| 肃宁县|