JS面向?qū)ο?/h1>

java中對象的兩個基本概念:
1.類:類是對象的模板,比如說Leader 這個是泛稱領(lǐng)導(dǎo),并不特指誰。
2:實例:實例是根據(jù)類創(chuàng)建的對象婶博,根據(jù)類Leader可以創(chuàng)建出很多實例:liyi,yingjiangyong等。每個實例表示具體的領(lǐng)導(dǎo)荧飞,他們
都屬于Leader類型凡人。
ES6之前的版本中沒有類和實例,是通過原型prototype完成面向?qū)ο缶幊獭?br> 區(qū)別:JS中沒有類和對象叹阔,所有的對象都是實例挠轴,只是把一個對象的原型指向另一個對象。

//創(chuàng)建對象的第一種方法:.proto
var Unical={
name:'liyi',
age:31,
hello:function(){
alert('Hello, '+this.name+'!');
}
}
var qinbb={
name:'qinbb',
age:24
}
qinbb.proto=Unical;
qinbb.name;//'qinbb'
qinbb.age;//24
qinbb.hello();//Hello, qinbb!
//原型鏈:qinbb--->Unical.prototype--->Object.prototype--->null
//將qinbb的原型指向Unical耳幢,因此可以繼承Unical里面的方法(.hello()),先在qinbb里面找岸晦,找不到再去原型里面找。
var leader={
name:'lipei',
age:30,
run:function(){
alert('My leader is '+this.name);
}
}
qinbb.proto=leader;
qinbb.name;//'qinbb'
qinbb.age;//24
qinbb.run();//My leader is qinbb
qinbb.hello();
//原型鏈:qinbb--->leader.prototype--->Object.prototype--->null
//報錯:qinbb.hello()不是一個方法睛藻,因為將原型指向了leader启上,之前的Unical將不再繼承
/*創(chuàng)建對象的第二種方法:Objece.create()
最好不要用.ptoto指向原型的對象,低版本的瀏覽器會不支持(IE瀏覽器就沒有)修档,
ES6版本以下的用Objece.create()來傳入原型對象,是創(chuàng)建原型繼承的一種方法碧绞。
*/
//創(chuàng)建對象的第二種方法Objece.create()
var Leader={
name:'lipei',
age:30,
run:function(){
alert('My leader is '+this.name);
}
}
//可以傳多個參數(shù)府框,但是順序要對應(yīng)上吱窝。
function CreateLeader(name,age){
// 基于leader原型創(chuàng)建一個新對象:
var s = Object.create(Leader);
// 初始化新對象:
s.name = name;
s.age = age;
return s;
}
var qinbb=CreateLeader('qinbb',24);
var qinbb=CreateLeader(24,'qinbb');//若是這樣姓名和年齡就對應(yīng)不上
//qinbb.proto===leader;//true qinbb的原型就是leader 通過構(gòu)造函數(shù)CreateLeader中的Objece.create()創(chuàng)建了qinbb
/
構(gòu)造函數(shù)創(chuàng)建對象
/
//創(chuàng)建對象的第三種方法:構(gòu)造函數(shù)(先定義一個構(gòu)造函數(shù),一定用關(guān)鍵字new來調(diào)用這個函數(shù)迫靖,并返回一個對象)
function Leader(name){
this.name=name;
this.hello=function(){
alert(this.name+' is a leader !');
}
}
var liyi= new Leader('liyi');
var qinbb = new Leader('qinbb');
liyi.hello===qinbb.hello;//輸出:false 雖然調(diào)用同一個函數(shù)院峡,但是并不相同 這個在方法四中講解
Object.getPrototypeOf(liyi);//輸出 Object {}
liyi.constructor===Leader.prototype.constructor;//true
liyi.proto===Leader.prototype;//true
Leader.prototype.constructor;
/輸出如下
function Leader(name){
this.name=name;
this.hello=function(){
alert(this.name+' is a leader !');
}
}/
Leader.prototype.constructor===Leader//輸出:true
/liyi的原型鏈:liyi-->Leader.prototype-->Object.prototype-->null
qinbb的原型鏈:qinbb-->Leader.prototype-->Object.prototype-->null
/
//創(chuàng)建對象的第四種方法:在方法三種進(jìn)行優(yōu)化,不用new來調(diào)用函數(shù)系宜。
function extendLeader(props){
this.name=props.name || '匿名';
this.grade=props.grade || '普通員工';
}
/run 實際上只需要共享同一個函數(shù)就可以了照激,這樣可以節(jié)省很多內(nèi)存,
只要把run函數(shù)移動到liyi盹牧、qinbb這些對象共同的原型上/
extendLeader.prototype.run=function(){
alert(this.name+' 的級別是: '+this.grade);
}
function CreateLeader(props){
return new extendLeader(props);
}
var liyi=CreateLeader({name:'liyi',grade:'經(jīng)理'});
var qinbb=CreateLeader({name:'qinbb'});
liyi.run===qinbb.run;//輸出true
/
*原型繼承俩垃,java 里面就是extends就可以繼承class類励幼,JS中要繼承,ES6版本以前的比較復(fù)雜口柳。
*需要構(gòu)造中間函數(shù)苹粟,并且將中間函數(shù)的原型指向需要繼承的對象,再將繼承的對象的原型指向中間函數(shù)跃闹。
*/
//構(gòu)造函數(shù)創(chuàng)建對象
function Leader(props){
this.name=props.name;
this.grade=props.grade || '普通員工';
}
function extendLeader(props){
Leader.call(this,props);
this.skill=props.skill || '暫無';
//return new extendLeader(props); 新建對象的時候 不用new
}
function F(){}//構(gòu)造中間函數(shù)
F.prototype=Leader.prototype;//將中間函數(shù)F的原型指向Leader的原型
//再將extendLeader的原型指向中間函數(shù)F的原型嵌削,也就是Leader的原型,此時extendLeader的構(gòu)造函數(shù)是Leader
extendLeader.prototype=new F();
//將extendLeader的構(gòu)造函數(shù)修復(fù)為extendLeader望艺,這樣的話extendLeader原型是Leader的原型苛秕,構(gòu)造函數(shù)是自己本身
extendLeader.prototype.constructor=extendLeader;
var liyi=new extendLeader({name:'liyi',skill:'互聯(lián)網(wǎng)技術(shù)都精通'});
liyi.name;//輸出‘liyi’
liyi.grade;//輸出:‘普通員工’
liyi.skill;//輸出:‘互聯(lián)網(wǎng)技術(shù)都精通’
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者

  • 序言:七十年代末,一起剝皮案震驚了整個濱河市找默,隨后出現(xiàn)的幾起案子艇劫,更是在濱河造成了極大的恐慌,老刑警劉巖啡莉,帶你破解...
    沈念sama閱讀 221,635評論 6 515
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件港准,死亡現(xiàn)場離奇詭異,居然都是意外死亡咧欣,警方通過查閱死者的電腦和手機(jī)浅缸,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 94,543評論 3 399
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來魄咕,“玉大人衩椒,你說我怎么就攤上這事弄抬《峙模” “怎么了锻煌?”我有些...
    開封第一講書人閱讀 168,083評論 0 360
  • 文/不壞的土叔 我叫張陵友驮,是天一觀的道長柏卤。 經(jīng)常有香客問我异旧,道長尤勋,這世上最難降的妖魔是什么侮措? 我笑而不...
    開封第一講書人閱讀 59,640評論 1 296
  • 正文 為了忘掉前任右遭,我火速辦了婚禮做盅,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘窘哈。我一直安慰自己吹榴,他們只是感情好,可當(dāng)我...
    茶點故事閱讀 68,640評論 6 397
  • 文/花漫 我一把揭開白布滚婉。 她就那樣靜靜地躺著图筹,像睡著了一般。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上远剩,一...
    開封第一講書人閱讀 52,262評論 1 308
  • 那天扣溺,我揣著相機(jī)與錄音,去河邊找鬼瓜晤。 笑死娇妓,一個胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的活鹰。 我是一名探鬼主播哈恰,決...
    沈念sama閱讀 40,833評論 3 421
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼志群!你這毒婦竟也來了着绷?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 39,736評論 0 276
  • 序言:老撾萬榮一對情侶失蹤锌云,失蹤者是張志新(化名)和其女友劉穎荠医,沒想到半個月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體桑涎,經(jīng)...
    沈念sama閱讀 46,280評論 1 319
  • 正文 獨居荒郊野嶺守林人離奇死亡彬向,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 38,369評論 3 340
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發(fā)現(xiàn)自己被綠了攻冷。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片娃胆。...
    茶點故事閱讀 40,503評論 1 352
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖等曼,靈堂內(nèi)的尸體忽然破棺而出里烦,到底是詐尸還是另有隱情,我是刑警寧澤禁谦,帶...
    沈念sama閱讀 36,185評論 5 350
  • 正文 年R本政府宣布胁黑,位于F島的核電站,受9級特大地震影響州泊,放射性物質(zhì)發(fā)生泄漏丧蘸。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點故事閱讀 41,870評論 3 333
  • 文/蒙蒙 一遥皂、第九天 我趴在偏房一處隱蔽的房頂上張望力喷。 院中可真熱鬧,春花似錦渴肉、人聲如沸冗懦。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,340評論 0 24
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至颈畸,卻和暖如春乌奇,著一層夾襖步出監(jiān)牢的瞬間没讲,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 33,460評論 1 272
  • 我被黑心中介騙來泰國打工礁苗, 沒想到剛下飛機(jī)就差點兒被人妖公主榨干…… 1. 我叫王不留爬凑,地道東北人。 一個月前我還...
    沈念sama閱讀 48,909評論 3 376
  • 正文 我出身青樓试伙,卻偏偏與公主長得像嘁信,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子疏叨,可洞房花燭夜當(dāng)晚...
    茶點故事閱讀 45,512評論 2 359

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