丸子學(xué)JS(學(xué)習(xí)1小時 - 面向?qū)ο蠡A(chǔ))

前言

一晃終于學(xué)到了面向?qū)ο笱及停@一塊花了好長一段時間去理解瞻赶,內(nèi)容不多但是需要時間去消化

對象是什么

1)對象是單個事物的抽象
2)對象是一個容器知押,封裝了屬性(property)和方法(method)

什么是面向?qū)ο?/h2>

面向?qū)ο蟛皇切碌臇|西,它只是過程式代碼的一種高度封裝暂氯,目的在于提高代碼的開發(fā)效率和可維護(hù)性。

創(chuàng)建對象

  • 簡單方式
    1亮蛔、new Object() 創(chuàng)建
var person = new Object()
    person.name = 'som'
    person.age = 18
    person.sayName = function() {
        console.log(this.name)
    }

2痴施、對象字面量創(chuàng)建

var person = {
    name: 'som',
    age: 18,
    sayName: function(){
        console.log(this.name)
    }
}
  • 工廠函數(shù)方式
function createPerson (name, age) {
  return {
    name: name,
    age: age,
    sayName: function () {
      console.log(this.name)
    }
  }
}

優(yōu)雅的工廠函數(shù) - 構(gòu)造函數(shù)

function Person (name, age) {
  this.name = name
  this.age = age
  this.sayName = function () {
    console.log(this.name)
  }
}

var p1 = new Person('Jack', 18)
p1.sayName() // => Jack

var p2 = new Person('Mike', 23)
p2.sayName() // => Mike

使用new 操作符構(gòu)造函數(shù)將經(jīng)歷下面4個步驟

  1. 創(chuàng)建一個新對象
  2. 將構(gòu)造函數(shù)的作用域賦給新對象(因此 this 就指向了這個新對象)
  3. 執(zhí)行構(gòu)造函數(shù)中的代碼
  4. 返回新對象

構(gòu)造函數(shù)和實(shí)例對象的關(guān)系

使用構(gòu)造函數(shù)的好處不僅僅在于代碼的簡潔性,更重要的是我們可以識別對象的具體類型了尔邓。在每一個實(shí)例對象中的proto中同時有一個 constructor 屬性晾剖,該屬性指向創(chuàng)建該實(shí)例的構(gòu)造函數(shù)

console.log(p1.constructor === Person) // => true
console.log(p2.constructor === Person) // => true
console.log(p1.constructor === p2.constructor) // => true

使用 instanceof 檢測實(shí)例是否屬于某個構(gòu)造函數(shù)構(gòu)建的

console.log(p1 instanceof Person) // => true
console.log(p2 instanceof Person) // => true

原型 prototype

每一個構(gòu)造函數(shù)都有一個prototype屬性,指向另一個對象梯嗽, 這個對象的所有屬性和方法都會被構(gòu)造函數(shù)的實(shí)例繼承

function Person (name, age) {
  this.name = name
  this.age = age
}
Person.prototype.type = 'human'

Person.prototype.sayName = function () {
  console.log(this.name)
}

var p1 = new Person(...)
var p2 = new Person(...)

console.log(p1.sayName === p2.sayName) // => true

構(gòu)造函數(shù)齿尽、實(shí)例、原型之間的關(guān)系

更簡單的原型寫法

function Person (name, age) {
  this.name = name
  this.age = age
}

Person.prototype = {
  constructor: Person, // => 手動將 constructor 指向正確的構(gòu)造函數(shù)
  type: 'human',
  sayHello: function () {
    console.log('我叫' + this.name + '灯节,我今年' + this.age + '歲了')
  }
}
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末循头,一起剝皮案震驚了整個濱河市,隨后出現(xiàn)的幾起案子炎疆,更是在濱河造成了極大的恐慌卡骂,老刑警劉巖,帶你破解...
    沈念sama閱讀 212,542評論 6 493
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件形入,死亡現(xiàn)場離奇詭異全跨,居然都是意外死亡,警方通過查閱死者的電腦和手機(jī)亿遂,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 90,596評論 3 385
  • 文/潘曉璐 我一進(jìn)店門浓若,熙熙樓的掌柜王于貴愁眉苦臉地迎上來渺杉,“玉大人,你說我怎么就攤上這事挪钓∈窃剑” “怎么了?”我有些...
    開封第一講書人閱讀 158,021評論 0 348
  • 文/不壞的土叔 我叫張陵碌上,是天一觀的道長倚评。 經(jīng)常有香客問我,道長馏予,這世上最難降的妖魔是什么天梧? 我笑而不...
    開封第一講書人閱讀 56,682評論 1 284
  • 正文 為了忘掉前任,我火速辦了婚禮吗蚌,結(jié)果婚禮上腿倚,老公的妹妹穿的比我還像新娘。我一直安慰自己蚯妇,他們只是感情好敷燎,可當(dāng)我...
    茶點(diǎn)故事閱讀 65,792評論 6 386
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著箩言,像睡著了一般硬贯。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上陨收,一...
    開封第一講書人閱讀 49,985評論 1 291
  • 那天饭豹,我揣著相機(jī)與錄音,去河邊找鬼务漩。 笑死拄衰,一個胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的饵骨。 我是一名探鬼主播翘悉,決...
    沈念sama閱讀 39,107評論 3 410
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼居触!你這毒婦竟也來了妖混?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 37,845評論 0 268
  • 序言:老撾萬榮一對情侶失蹤轮洋,失蹤者是張志新(化名)和其女友劉穎制市,沒想到半個月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體弊予,經(jīng)...
    沈念sama閱讀 44,299評論 1 303
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡祥楣,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 36,612評論 2 327
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發(fā)現(xiàn)自己被綠了。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片荣堰。...
    茶點(diǎn)故事閱讀 38,747評論 1 341
  • 序言:一個原本活蹦亂跳的男人離奇死亡床未,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出振坚,到底是詐尸還是另有隱情,我是刑警寧澤斋扰,帶...
    沈念sama閱讀 34,441評論 4 333
  • 正文 年R本政府宣布渡八,位于F島的核電站,受9級特大地震影響传货,放射性物質(zhì)發(fā)生泄漏屎鳍。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 40,072評論 3 317
  • 文/蒙蒙 一问裕、第九天 我趴在偏房一處隱蔽的房頂上張望逮壁。 院中可真熱鬧,春花似錦粮宛、人聲如沸窥淆。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,828評論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至筷畦,卻和暖如春词裤,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背鳖宾。 一陣腳步聲響...
    開封第一講書人閱讀 32,069評論 1 267
  • 我被黑心中介騙來泰國打工吼砂, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人鼎文。 一個月前我還...
    沈念sama閱讀 46,545評論 2 362
  • 正文 我出身青樓渔肩,卻偏偏與公主長得像,于是被迫代替她去往敵國和親漂问。 傳聞我的和親對象是個殘疾皇子赖瞒,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 43,658評論 2 350

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