亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

JavaScript中構(gòu)造函數(shù)與原型鏈之間的關(guān)系詳解

 更新時(shí)間:2019年02月25日 08:36:52   投稿:laozhang  
在本篇文章里小編給大家分享了關(guān)于JavaScript中構(gòu)造函數(shù)與原型鏈之間的關(guān)系相關(guān)知識(shí)點(diǎn),需要的朋友們學(xué)習(xí)下。

在Javascript中不存在class的概念,它的class概念是通過(guò)構(gòu)造函數(shù)(constructor)與原型鏈(prototype)來(lái)實(shí)現(xiàn)。

1.構(gòu)造函數(shù)(constructor):創(chuàng)建對(duì)象時(shí)的初始化對(duì)象,總是與new 關(guān)鍵是一同出現(xiàn)。

構(gòu)造函數(shù)存在以下特點(diǎn):

  • 1、構(gòu)造函數(shù)內(nèi)的this 指向當(dāng)前實(shí)例對(duì)象。
  • 2、使用new 關(guān)鍵字實(shí)例化當(dāng)前對(duì)象。
  • 3、構(gòu)造函數(shù)首字母大寫(xiě),區(qū)分普通函數(shù)。
  • 4、實(shí)例對(duì)象都可以繼承構(gòu)造函數(shù)中的屬性和方法。但是,同一個(gè)對(duì)象實(shí)例之間,無(wú)法共享屬性。

2.原型(prototype):是一個(gè)對(duì)象,實(shí)現(xiàn)對(duì)象的屬性繼承。javascript 中的對(duì)象通過(guò) proto 來(lái)指向原型對(duì)象,可以通過(guò)Object.__proto__ 來(lái)訪問(wèn)

3.構(gòu)造函數(shù)與與原型的聯(lián)系:

 <script>
  function Demo(){
       
   }
   var demo = new Demo()
   var data= demo.prototype = function(){
 
   }
   
   console.log(demo.__proto__)
   console.log(data.constructor )
   console.log(data.prototype.__proto__)
   console.log(demo.constructor.prototype)
   console.log(demo.constructor)
  輸出:
  {constructor: ƒ}constructor: ƒ Demo()__proto__: Object
  ƒ Function() { [native code] }
  {constructor: ƒ, __defineGetter__: ƒ, __defineSetter__: ƒ, hasOwnProperty: ƒ, __lookupGetter__: ƒ, …}
  {constructor: ƒ}
  ƒ Demo(){  }
</script>

從以上輸出結(jié)果可以看出:

構(gòu)造函數(shù)的 __proto__ 指向原型對(duì)象;
原型的constructor 指向構(gòu)造函數(shù)Function;
原型的 prototype.__proto__ 等于 Object.__proto__;
實(shí)例 的 constructor.prototype 指向原型;
實(shí)例的constructor 指向構(gòu)造函數(shù)

引用圖例:

![1460000018155881][1]

相關(guān)文章

  • js不是基礎(chǔ)的基礎(chǔ)

    js不是基礎(chǔ)的基礎(chǔ)

    js不是基礎(chǔ)的基礎(chǔ)...
    2006-12-12
  • 常用的Javascript數(shù)據(jù)驗(yàn)證插件

    常用的Javascript數(shù)據(jù)驗(yàn)證插件

    本文主要介紹的是常用的Javascript數(shù)據(jù)驗(yàn)證插件,包括電話號(hào)碼驗(yàn)證,郵件驗(yàn)證,身份證驗(yàn)證,需要的朋友可以參考下
    2015-08-08
  • appendChild() 或 insertBefore()使用與區(qū)別介紹

    appendChild() 或 insertBefore()使用與區(qū)別介紹

    appendChild() 方法在節(jié)點(diǎn)的子節(jié)點(diǎn)列表末添加新的子節(jié)點(diǎn)。insertBefore() 方法在節(jié)點(diǎn)的子節(jié)點(diǎn)列表任意位置插入新的節(jié)點(diǎn),下面為大家介紹下具體的使用,感興趣的朋友不要錯(cuò)過(guò)
    2013-10-10
  • JavaScript DOM 學(xué)習(xí)第二章 編輯文本

    JavaScript DOM 學(xué)習(xí)第二章 編輯文本

    在這一章我會(huì)給出一個(gè)在CMS里非常有用的更新頁(yè)面的代碼。在任一段落點(diǎn)擊鼠標(biāo)你就可以修改了。完成以后點(diǎn)擊按鈕,修改的文本就顯示了。
    2010-02-02
  • js轉(zhuǎn)義字符介紹

    js轉(zhuǎn)義字符介紹

    有時(shí)候js得到j(luò)son串中含有"<"和">" ,那么兩個(gè)尖括號(hào)中間的文字是無(wú)法在html頁(yè)面顯示出來(lái)的,必須用轉(zhuǎn)義字符
    2013-11-11
  • JavaScript中用let語(yǔ)句聲明作用域的用法講解

    JavaScript中用let語(yǔ)句聲明作用域的用法講解

    首先要注意let是ES6中的東西,起碼是IE10之前的IE瀏覽器兼容要千萬(wàn)當(dāng)心!嗯...然后我們來(lái)看JavaScript中用let語(yǔ)句聲明作用域的用法講解
    2016-05-05
  • JavaScript的類(lèi)型簡(jiǎn)單說(shuō)明

    JavaScript的類(lèi)型簡(jiǎn)單說(shuō)明

    JavaScript變量有2中類(lèi)型:原始類(lèi)型和引用值類(lèi)型。
    2010-09-09
  • 深入解析contentWindow, contentDocument

    深入解析contentWindow, contentDocument

    沒(méi)有永恒的技術(shù)只有需求,沒(méi)有好說(shuō)的客戶(hù)只有無(wú)奈的開(kāi)發(fā)者,如果iframe的出現(xiàn)是一個(gè)錯(cuò)誤的話,iframe里邊在來(lái)一個(gè)iframe那是錯(cuò)上加錯(cuò),神話沒(méi)有在遠(yuǎn)古的塵囂中消失,卻在懷具的今天不斷上演
    2013-07-07
  • jquery中prop()方法和attr()方法的區(qū)別淺析

    jquery中prop()方法和attr()方法的區(qū)別淺析

    官方例舉的例子感覺(jué)和attr()差不多,也不知道有什么區(qū)別,既然有了prop()這個(gè)新方法,不可能沒(méi)用吧,那什么時(shí)候該用attr(),什么時(shí)候該用prop()呢
    2013-09-09
  • document 和 document.all 分別什么時(shí)候用

    document 和 document.all 分別什么時(shí)候用

    document 和 document.all 分別什么時(shí)候用...
    2006-09-09

最新評(píng)論