07_函數(shù)的prototype

原型prototype
  • 我們所創(chuàng)建的每一個函數(shù)雕崩,解析器都會向函數(shù)中添加一個屬性prototype,這個屬性對應著一個對象狸吞,這個對象就是我們所謂的原型對象
  • 如果函數(shù)作為普通函數(shù)調用prototype沒有任何作用
  • 當函數(shù)以構造函數(shù)的形式調用時勉耀,它所創(chuàng)建的對象中都會有一個隱含的屬性指煎,指向該構造函數(shù)的原型對象,我們可以通過 _ _proto_ _ 來訪問該屬性.
  • 原型對象就相當于一個公共的區(qū)域瑰排,所有同一個類的實例都可以訪問到這個原型對象贯要,我們可以將對象中共有的內容暖侨,統(tǒng)一設置到原型對象中椭住。
function MyClass(){
}
    MyClass.prototype.a = 123;  //向MyClass的原型中添加屬性a
    MyClass.prototype.sayHello = function(){ //向MyClass的原型中添加一個方法
      alert("hello");
    };
  • 當我們訪問對象的一個屬性或方法時,它會先在對象自身中尋找字逗,如果有則直接使用.如果沒有則會去原型對象中尋找京郑,如果找到則直接使用

以后我們創(chuàng)建構造函數(shù)時,可以將這些對象共有的屬性和方法葫掉,統(tǒng)一添加到構造函數(shù)的原型對象中些举,這樣不用分別為每一個對象添加,也不會影響到全局作用域俭厚,就可以使每個對象都具有這些屬性和方法了

圖片.png

函數(shù)的prototype屬性

  • 每個函數(shù)都有一個prototype屬性, 它默認指向一個Object空對象(即稱為: 原型對象)
  • 原型對象中有一個屬性constructor, 它指向函數(shù)對象
  • prototype對象有一個constructor屬性户魏,默認只想prototype對象所在的構造函數(shù)。
  • 作用:constructor屬性作用挪挤,是分辨原型對象到底屬于哪個構造函數(shù)叼丑。
圖片.png
// 每個函數(shù)都有一個prototype屬性, 它默認指向一個對象(即稱為: 原型對象)
  console.log(Date.prototype, typeof Date.prototype)
  function fn() {
  }
  console.log(fn.prototype, typeof fn.prototype)

  // 原型對象中有一個屬性constructor, 它指向函數(shù)對象
  console.log(Date.prototype.constructor===Date)  //ture
  console.log(fn.prototype.constructor===fn)   //ture

給原型對象添加屬性(一般都是方法)

  • 作用: 函數(shù)的所有實例對象自動擁有原型中的屬性(方法)
// 2. 給原型對象添加屬性(一般都是方法)
  function F() {

  }
  F.prototype.age = 12 //添加屬性
  F.prototype.setAge = function (age) { // 添加方法
    this.age = age
  }
  // 創(chuàng)建函數(shù)的實例對象
  var f = new F()
  console.log(f.age)
  f.setAge(23)
  console.log(f.age)

顯式原型與隱式原型

  • 每個函數(shù)function都有一個prototype,即顯式原型
  • 每個實例對象都有一個_ _proto_ _扛门,可稱為隱式原型
  • 對象的隱式原型的值為其對應構造函數(shù)的顯式原型的值
  • 內存結構(圖)
  • 總結:
    • 函數(shù)的prototype屬性: 在定義函數(shù)時自動添加的, 默認值是一個空Object對象
    • 對象的_ _proto_ _屬性: 創(chuàng)建對象時自動添加的, 默認值為構造函數(shù)的prototype屬性值
    • 程序員能直接操作顯式原型, 但不能直接操作隱式原型(ES6之前)
  //定義構造函數(shù)
  function Fn() {   // 內部語句: this.prototype = {}

  }
  // 1. 每個函數(shù)function都有一個prototype鸠信,即顯式原型屬性, 默認指向一個空的Object對象
  console.log(Fn.prototype)
  // 2. 每個實例對象都有一個__proto__,可稱為隱式原型
  //創(chuàng)建實例對象
  var fn = new Fn()  // 內部語句: this.__proto__ = Fn.prototype
  console.log(fn.__proto__)
  // 3. 對象的隱式原型的值為其對應構造函數(shù)的顯式原型的值
  console.log(Fn.prototype===fn.__proto__) // true
  //給原型添加方法
  Fn.prototype.test = function () {
    console.log('test()')
  }
  //通過實例調用原型的方法
  fn.test()
顯式原型與隱式原型.png
最后編輯于
?著作權歸作者所有,轉載或內容合作請聯(lián)系作者
  • 序言:七十年代末论寨,一起剝皮案震驚了整個濱河市星立,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌葬凳,老刑警劉巖绰垂,帶你破解...
    沈念sama閱讀 219,366評論 6 508
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異火焰,居然都是意外死亡劲装,警方通過查閱死者的電腦和手機,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,521評論 3 395
  • 文/潘曉璐 我一進店門荐健,熙熙樓的掌柜王于貴愁眉苦臉地迎上來酱畅,“玉大人,你說我怎么就攤上這事江场》乃幔” “怎么了?”我有些...
    開封第一講書人閱讀 165,689評論 0 356
  • 文/不壞的土叔 我叫張陵址否,是天一觀的道長餐蔬。 經(jīng)常有香客問我碎紊,道長,這世上最難降的妖魔是什么樊诺? 我笑而不...
    開封第一講書人閱讀 58,925評論 1 295
  • 正文 為了忘掉前任仗考,我火速辦了婚禮,結果婚禮上词爬,老公的妹妹穿的比我還像新娘秃嗜。我一直安慰自己,他們只是感情好顿膨,可當我...
    茶點故事閱讀 67,942評論 6 392
  • 文/花漫 我一把揭開白布锅锨。 她就那樣靜靜地躺著,像睡著了一般恋沃。 火紅的嫁衣襯著肌膚如雪必搞。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 51,727評論 1 305
  • 那天囊咏,我揣著相機與錄音恕洲,去河邊找鬼。 笑死梅割,一個胖子當著我的面吹牛霜第,可吹牛的內容都是我干的。 我是一名探鬼主播炮捧,決...
    沈念sama閱讀 40,447評論 3 420
  • 文/蒼蘭香墨 我猛地睜開眼庶诡,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了咆课?” 一聲冷哼從身側響起末誓,我...
    開封第一講書人閱讀 39,349評論 0 276
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎书蚪,沒想到半個月后喇澡,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 45,820評論 1 317
  • 正文 獨居荒郊野嶺守林人離奇死亡殊校,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內容為張勛視角 年9月15日...
    茶點故事閱讀 37,990評論 3 337
  • 正文 我和宋清朗相戀三年晴玖,在試婚紗的時候發(fā)現(xiàn)自己被綠了。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片为流。...
    茶點故事閱讀 40,127評論 1 351
  • 序言:一個原本活蹦亂跳的男人離奇死亡呕屎,死狀恐怖,靈堂內的尸體忽然破棺而出敬察,到底是詐尸還是另有隱情秀睛,我是刑警寧澤,帶...
    沈念sama閱讀 35,812評論 5 346
  • 正文 年R本政府宣布莲祸,位于F島的核電站蹂安,受9級特大地震影響椭迎,放射性物質發(fā)生泄漏。R本人自食惡果不足惜田盈,卻給世界環(huán)境...
    茶點故事閱讀 41,471評論 3 331
  • 文/蒙蒙 一畜号、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧允瞧,春花似錦简软、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,017評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽语泽。三九已至贸典,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間踱卵,已是汗流浹背廊驼。 一陣腳步聲響...
    開封第一講書人閱讀 33,142評論 1 272
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留惋砂,地道東北人妒挎。 一個月前我還...
    沈念sama閱讀 48,388評論 3 373
  • 正文 我出身青樓,卻偏偏與公主長得像西饵,于是被迫代替她去往敵國和親酝掩。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當晚...
    茶點故事閱讀 45,066評論 2 355

推薦閱讀更多精彩內容