JS繼承

1:原型繼承

為了讓子類繼承父類的屬性(也包括方法),首先需要定義一個(gè)構(gòu)造函數(shù)盟蚣。然后黍析,將父類的新實(shí)例賦值給構(gòu)造函數(shù)的原型。代碼如下:

eg:原型繼承

//全是改變的指針模擬繼承 new this指針改變 通過(guò)綁定prototype復(fù)制指針改變
function proto(){
this.name="caoshiyuan"http://如果this不懂看下一個(gè)類式繼承
}
function child(){
this.age=23
}
function generator(){
var name=123
}
console.log(child.constructor)
console.log(proto.constructor)
console.log(generator.constructor())
console.log(generator.constructor)
// ------------以上可以略過(guò)
child.prototype=new proto()
let childs=new child()
console.log(childs.name)//caoshiyuan
console.log(childs)//沒(méi)有name
console.log(childs.proto)//只有name指向原型 proto指向?qū)嵗瘮?shù)的原型 他的原型是一個(gè)指針指向proto函數(shù)
console.log(child.prototype)//和上面相等

2:類式繼承

主要使用call apply 方法實(shí)現(xiàn)繼承
1屎开、方法定義
call方法: 語(yǔ)法:call([thisObj[,arg1[, arg2[, [,.argN]]]]]) 定義:調(diào)用一個(gè)對(duì)象的一個(gè)方法阐枣,以另一個(gè)對(duì)象替換當(dāng)前對(duì)象。 說(shuō)明: call 方法可以用來(lái)代替另一個(gè)對(duì)象調(diào)用一個(gè)方法。call 方法可將一個(gè)函數(shù)的對(duì)象上下文從初始的上下文改變?yōu)橛?thisObj 指定的新對(duì)象蔼两。 如果沒(méi)有提供 thisObj 參數(shù)甩鳄,那么 Global 對(duì)象被用作 thisObj。 apply方法: 語(yǔ)法:apply([thisObj[,argArray]]) 定義:應(yīng)用某一對(duì)象的一個(gè)方法额划,用另一個(gè)對(duì)象替換當(dāng)前對(duì)象妙啃。 說(shuō)明: 如果 argArray 不是一個(gè)有效的數(shù)組或者不是 arguments 對(duì)象,那么將導(dǎo)致一個(gè) TypeError俊戳。 如果沒(méi)有提供 argArray 和 thisObj 任何一個(gè)參數(shù)揖赴,那么 Global 對(duì)象將被用作 thisObj, 并且無(wú)法被傳遞任何參數(shù)品抽。

eg: call

function add(a,b)
{
alert(a+b);
}
function sub(a,b)
{
alert(a-b);
}

add.call(sub,3,1);

這個(gè)例子中的意思就是用 add 來(lái)替換 sub储笑,add.call(sub,3,1) == add(3,1) ,所以運(yùn)行結(jié)果為:alert(4); // 注意:js 中的函數(shù)其實(shí)是對(duì)象圆恤,函數(shù)名是對(duì) Function 對(duì)象的引用突倍。

b、
function Animal(){
this.name = "Animal";
this.showName = function(){
alert(this.name);
}
}

function Cat(){
this.name = "Cat";
}

var animal = new Animal();
var cat = new Cat();

//通過(guò)call或apply方法盆昙,將原本屬于Animal對(duì)象的showName()方法交給對(duì)象cat來(lái)使用了羽历。
//輸入結(jié)果為"Cat"
animal.showName.call(cat,",");
//animal.showName.apply(cat,[]);

call 的意思是把 animal 的方法放到cat上執(zhí)行,原來(lái)cat是沒(méi)有showName() 方法淡喜,現(xiàn)在是把a(bǔ)nimal 的showName()方法放到 cat上來(lái)執(zhí)行秕磷,所以this.name 應(yīng)該是 Cat

c、實(shí)現(xiàn)繼承
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對(duì)象代替this對(duì)象炼团,那么 Cat中不就有Animal的所有屬性和方法了嗎澎嚣,Cat對(duì)象就能夠直接調(diào)用Animal的方法以及屬性了.

d、多重繼承
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);
}

很簡(jiǎn)單瘟芝,使用兩個(gè) call 就實(shí)現(xiàn)多重繼承了當(dāng)然易桃,js的繼承還有其他方法,例如使用原型鏈锌俱,這個(gè)不屬于本文的范疇晤郑,只是在此說(shuō)明call 的用法。說(shuō)了call 贸宏,當(dāng)然還有 apply造寝,這兩個(gè)方法基本上是一個(gè)意思,區(qū)別在于 call 的第二個(gè)參數(shù)可以是任意類型吭练,而apply的第二個(gè)參數(shù)必須是數(shù)組诫龙,也可以是arguments還有 callee,caller.
上面實(shí)在看不懂在下謝了一些小例子

eg://類式繼承

function Super(){
this.colors=["red","blue"];
}
function Sub(){
Super.call(this);//這里利用call更改this指向
}
console.log(Sub)
console.log(Sub.prototype)//空的證明了什么?空的證明了什么?
let sub=new Sub()
console.log(sub.colors)

//call
// function add(a,b){
// alert(a+b)
// }
// function cal(a,b){
// alert(a-b)
// }
// add.call(cal,2,3)

function add1(a,b){
alert(a+b)
}
function cal1(a,b){

add1.call(this,a,b)//this 后面的值是傳入的參數(shù) apply是數(shù)組形式

}
let add11=new cal1(1,2).

組合繼承 原型+類式

// 組合繼承 原型一般都是放的方法

function Parent(age){
this.name = ['mike','jack','smith'];
this.age = age;
}
Parent.prototype.run = function () {
return this.name + ' are both' + this.age;
};
function Child(age){
Parent.call(this,age);//對(duì)象冒充线脚,給超類型傳參 } Child.prototype = new Parent();//原型鏈繼承
var test = new Child(21);//寫(xiě)new Parent(21)也行 alert(test.run());//mike,jack,smith are both21
}

//寄生模式
// 這種繼承方式是把原型式+工廠模式結(jié)合起來(lái)赐稽,目的是為了封裝創(chuàng)建的過(guò)程叫榕。

function create(o){
    var f= obj(o);
    f.run = function () {
        return this.arr;//同樣浑侥,會(huì)共享引用
    };
    return f;
}

//寄生式組合

function obj(o){
    function F(){}
    F.prototype = o;
    return new F();
}
function create(parent,test){
    var f = obj(parent.prototype);//創(chuàng)建對(duì)象
    f.constructor = test;//增強(qiáng)對(duì)象
}

function Parent(name){
this.name = name;
this.arr = ['brother','sister','parents'];
}
Parent.prototype.run = function () {
return this.name;
};
function Child(name,age){
Parent.call(this,name);
this.age =age;
}
inheritPrototype(Parent,Child);//通過(guò)這里實(shí)現(xiàn)繼承

var test = new Child('trigkit4',21);
test.arr.push('nephew');
alert(test.arr);//
alert(test.run());//只共享了方法

var test2 = new Child('jack',22);
alert(test2.arr);//引用問(wèn)題解決
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末姊舵,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子寓落,更是在濱河造成了極大的恐慌括丁,老刑警劉巖,帶你破解...
    沈念sama閱讀 216,496評(píng)論 6 501
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件伶选,死亡現(xiàn)場(chǎng)離奇詭異史飞,居然都是意外死亡,警方通過(guò)查閱死者的電腦和手機(jī)仰税,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,407評(píng)論 3 392
  • 文/潘曉璐 我一進(jìn)店門(mén)构资,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái),“玉大人陨簇,你說(shuō)我怎么就攤上這事吐绵。” “怎么了河绽?”我有些...
    開(kāi)封第一講書(shū)人閱讀 162,632評(píng)論 0 353
  • 文/不壞的土叔 我叫張陵己单,是天一觀的道長(zhǎng)。 經(jīng)常有香客問(wèn)我耙饰,道長(zhǎng)纹笼,這世上最難降的妖魔是什么? 我笑而不...
    開(kāi)封第一講書(shū)人閱讀 58,180評(píng)論 1 292
  • 正文 為了忘掉前任苟跪,我火速辦了婚禮廷痘,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘件已。我一直安慰自己笋额,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,198評(píng)論 6 388
  • 文/花漫 我一把揭開(kāi)白布拨齐。 她就那樣靜靜地躺著鳞陨,像睡著了一般。 火紅的嫁衣襯著肌膚如雪瞻惋。 梳的紋絲不亂的頭發(fā)上厦滤,一...
    開(kāi)封第一講書(shū)人閱讀 51,165評(píng)論 1 299
  • 那天,我揣著相機(jī)與錄音歼狼,去河邊找鬼掏导。 笑死,一個(gè)胖子當(dāng)著我的面吹牛羽峰,可吹牛的內(nèi)容都是我干的趟咆。 我是一名探鬼主播添瓷,決...
    沈念sama閱讀 40,052評(píng)論 3 418
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼值纱!你這毒婦竟也來(lái)了鳞贷?” 一聲冷哼從身側(cè)響起,我...
    開(kāi)封第一講書(shū)人閱讀 38,910評(píng)論 0 274
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤虐唠,失蹤者是張志新(化名)和其女友劉穎搀愧,沒(méi)想到半個(gè)月后,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體疆偿,經(jīng)...
    沈念sama閱讀 45,324評(píng)論 1 310
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡咱筛,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,542評(píng)論 2 332
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了杆故。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片迅箩。...
    茶點(diǎn)故事閱讀 39,711評(píng)論 1 348
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖处铛,靈堂內(nèi)的尸體忽然破棺而出饲趋,到底是詐尸還是另有隱情,我是刑警寧澤罢缸,帶...
    沈念sama閱讀 35,424評(píng)論 5 343
  • 正文 年R本政府宣布篙贸,位于F島的核電站,受9級(jí)特大地震影響枫疆,放射性物質(zhì)發(fā)生泄漏爵川。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,017評(píng)論 3 326
  • 文/蒙蒙 一息楔、第九天 我趴在偏房一處隱蔽的房頂上張望寝贡。 院中可真熱鬧,春花似錦值依、人聲如沸圃泡。這莊子的主人今日做“春日...
    開(kāi)封第一講書(shū)人閱讀 31,668評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)颇蜡。三九已至,卻和暖如春辆亏,著一層夾襖步出監(jiān)牢的瞬間风秤,已是汗流浹背。 一陣腳步聲響...
    開(kāi)封第一講書(shū)人閱讀 32,823評(píng)論 1 269
  • 我被黑心中介騙來(lái)泰國(guó)打工扮叨, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留缤弦,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 47,722評(píng)論 2 368
  • 正文 我出身青樓彻磁,卻偏偏與公主長(zhǎng)得像碍沐,于是被迫代替她去往敵國(guó)和親狸捅。 傳聞我的和親對(duì)象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,611評(píng)論 2 353

推薦閱讀更多精彩內(nèi)容

  • 開(kāi)山例子 需求:學(xué)生交學(xué)費(fèi)累提,中學(xué)生打8折尘喝;小學(xué)生打5折,然后通過(guò)打印的方法刻恭,顯示學(xué)生的名字瞧省、年齡記應(yīng)繳學(xué)費(fèi)扯夭。 我們...
    jayafs閱讀 571評(píng)論 0 50
  • 對(duì)于js繼承一直都是半懂半不懂的狀態(tài)鳍贾,感覺(jué)需要整理一下: 參考自:JavaScript原型繼承工作原理JavaSc...
    博客專用馬甲閱讀 4,215評(píng)論 2 20
  • 一构拳、call()和apply()方法 1.方法定義 call方法: 語(yǔ)法:call([thisObj[,arg1[...
    O你的微笑好美O閱讀 385評(píng)論 0 0
  • 借用構(gòu)造函數(shù)繼承 原型鏈?zhǔn)嚼^承(借用原型鏈實(shí)現(xiàn)繼承) 組合式繼承 組合式繼承優(yōu)化1 組合式繼承優(yōu)化2 ES6中繼承...
    lxt410725閱讀 302評(píng)論 0 1
  • 我租房子的那個(gè)小區(qū)群的馬路頂頭喇叭口咆爽,是個(gè)水果鋪,水果品種豐富置森,鋪?zhàn)雍?jiǎn)易斗埂。 鋪?zhàn)邮且环N簡(jiǎn)易的鋁合金玻璃房,但主要的...
    薇薇安的30天閱讀 317評(píng)論 1 0