国产99久久精品_欧美日本韩国一区二区_激情小说综合网_欧美一级二级视频_午夜av电影_日本久久精品视频

最新文章專題視頻專題問答1問答10問答100問答1000問答2000關鍵字專題1關鍵字專題50關鍵字專題500關鍵字專題1500TAG最新視頻文章推薦1 推薦3 推薦5 推薦7 推薦9 推薦11 推薦13 推薦15 推薦17 推薦19 推薦21 推薦23 推薦25 推薦27 推薦29 推薦31 推薦33 推薦35 推薦37視頻文章20視頻文章30視頻文章40視頻文章50視頻文章60 視頻文章70視頻文章80視頻文章90視頻文章100視頻文章120視頻文章140 視頻2關鍵字專題關鍵字專題tag2tag3文章專題文章專題2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章專題3
問答文章1 問答文章501 問答文章1001 問答文章1501 問答文章2001 問答文章2501 問答文章3001 問答文章3501 問答文章4001 問答文章4501 問答文章5001 問答文章5501 問答文章6001 問答文章6501 問答文章7001 問答文章7501 問答文章8001 問答文章8501 問答文章9001 問答文章9501
當前位置: 首頁 - 科技 - 知識百科 - 正文

JS中call和apply函數用法實例分析

來源:懂視網 責編:小采 時間:2020-11-27 22:12:33
文檔

JS中call和apply函數用法實例分析

JS中call和apply函數用法實例分析:本文實例講述了JS中call和apply函數用法。分享給大家供大家參考,具體如下: call 函數 語法 obj.call(thisObj,arg[,arg2[,arg3[...agr]]]); 簡介 thisObj繼承obj的屬性和方法(obj原型鏈上的屬性和方法不能被繼承),后面的參數會當成obj的參數安裝順
推薦度:
導讀JS中call和apply函數用法實例分析:本文實例講述了JS中call和apply函數用法。分享給大家供大家參考,具體如下: call 函數 語法 obj.call(thisObj,arg[,arg2[,arg3[...agr]]]); 簡介 thisObj繼承obj的屬性和方法(obj原型鏈上的屬性和方法不能被繼承),后面的參數會當成obj的參數安裝順

本文實例講述了JS中call和apply函數用法。分享給大家供大家參考,具體如下:

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
*/

更多關于JavaScript相關內容感興趣的讀者可查看本站專題:《javascript面向對象入門教程》、《JavaScript錯誤與調試技巧總結》、《JavaScript數據結構與算法技巧總結》、《JavaScript遍歷算法與技巧總結》及《JavaScript數學運算用法總結》

希望本文所述對大家JavaScript程序設計有所幫助。

聲明:本網頁內容旨在傳播知識,若有侵權等問題請及時與本網聯系,我們將在第一時間刪除處理。TEL:177 7030 7066 E-MAIL:11247931@qq.com

文檔

JS中call和apply函數用法實例分析

JS中call和apply函數用法實例分析:本文實例講述了JS中call和apply函數用法。分享給大家供大家參考,具體如下: call 函數 語法 obj.call(thisObj,arg[,arg2[,arg3[...agr]]]); 簡介 thisObj繼承obj的屬性和方法(obj原型鏈上的屬性和方法不能被繼承),后面的參數會當成obj的參數安裝順
推薦度:
  • 熱門焦點

最新推薦

猜你喜歡

熱門推薦

專題
Top
主站蜘蛛池模板: 亚洲欧美日韩激情在线观看 | 亚洲专区路线一路线二天美 | 国产高清不卡码一区二区三区 | 欧美国产精品一区二区免费 | 91精品国产色综合久久不卡蜜 | 国产伦精品一区二区三区 | 在线观看网站国产 | 日韩中文字幕a | 一边摸一边叫床一边爽视频 | 久久九九视频 | 欧美性第一页 | 精品72久久久久久久中文字幕 | 久久无码av三级 | 国产一区免费在线观看 | 欧美色图日韩 | 欧美精品在线看 | 亚洲精品国产成人99久久 | 日韩另类 | 一级毛片黄 | 欧美激情一区二区三区 | 中文国产成人精品久久96 | 日韩理论在线 | 欧美人与禽zozzo性伦交 | 视频精品一区二区 | 欧美另类一区 | 欧美一区二区三区香蕉视 | 国产在线欧美日韩一区二区 | 国产呦系列 欧美呦 日韩呦 | 国产精品视频免费视频 | 日韩欧美爱爱 | 另类国产精品一区二区 | 欧美色图日韩 | 精品国产一区二区三区免费看 | 亚洲电影网址 | 国产精品美女一区二区三区 | 欧美日韩另类综合 | 国产一区二区三区视频 | 免费一看一级毛片全播放 | 久久久久国产成人精品亚洲午夜 | 国产欧美日韩中文字幕 | 美国一级大黄大色毛片视频一 |