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

歡迎訪問 生活随笔!

生活随笔

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

javascript

JavaScript call,apply和prototype的介绍,区别

發(fā)布時間:2023/12/18 javascript 28 豆豆
生活随笔 收集整理的這篇文章主要介紹了 JavaScript call,apply和prototype的介绍,区别 小編覺得挺不錯的,現(xiàn)在分享給大家,幫大家做個參考.

----這三個概念會在實現(xiàn)js繼承中使用到

1.call和apply

call和apply的作用基本類似,都是去執(zhí)行function并將這個function的context替換成第一個參數(shù)帶入。兩者的不同是call必須將function的參數(shù)一一帶入,而apply只要在第二個參數(shù)帶入一個數(shù)列。

1 function fn(arg1,arg2,arg3,...){ 2 //do something 3 } 4 5 fn(arg1,arg2,...); 6 7 fn.call(context,arg1,arg2,...); 8 9 fn.apply(context,[arg1,arg2,...]);

call方法調(diào)用一個對象的一個方法,以另一個對象替換當前對象。

call([thisObj[arg1[,arg2[,...[,argN]]]]])

參數(shù):thisObj可選,用作當前對象的對象;arg1,arg2,...argN可選,將被傳遞方法參數(shù)序列。

如果沒有提供thisObj,那么Global對象將被用作thisObj。

var func=new function(){this.a="func"};var newfunc=function(x){var a="newfunc";console.info(this.a);console.info(x); };newfunc.call(func,"hello world");//output:func hello world

?

2.prototype

?JavaScript沒有子類和父類的概念,靠原型鏈(prototype chain)模式來實現(xiàn)繼承。

prototype是構(gòu)造函數(shù)的一個屬性。

所有實例對象需要共享的屬性和方法,都放在這個prototype對象里面;那些不需要共享的屬性放在構(gòu)造函數(shù)里。

實例對象一旦創(chuàng)建,將自動引用prototype對象的屬性和方法。實例對象的屬性和方法分兩種,一種是共享的,另一種是本地自己的。

1 //example 1 2 function Person(name){ 3 this.name=name; 4 } 5 6 var person1=new Person('Mike'); 7 var person2=new Person('Linda'); 8 person2.gender='female'; 9 console.info(person1.gender);//undefinded 10 console.info(person2.gender);//female 11
12 //example 2 13 function Person(name){ 14 this.name=name; 15 } 16 17 Person.prototype.gender='male'; 18 var person1=new Person('Mike'); 19 var person2=new Person('Linda'); 20 person2.gender='female'; 21 console.info(person1.gender);//male 22 console.info(person2.gender);//female

比較上面兩個例子就知道了。

?

轉(zhuǎn)載于:https://www.cnblogs.com/deric/p/7081557.html

總結(jié)

以上是生活随笔為你收集整理的JavaScript call,apply和prototype的介绍,区别的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網(wǎng)站內(nèi)容還不錯,歡迎將生活随笔推薦給好友。