国产精品电影_久久视频免费_欧美日韩国产激情_成年人视频免费在线播放_日本久久亚洲电影_久久都是精品_66av99_九色精品美女在线_蜜臀a∨国产成人精品_冲田杏梨av在线_欧美精品在线一区二区三区_麻豆mv在线看

JavaScript類和繼承:constructor屬性

開發 前端
本文介紹了JavaScript里面的constructor屬性。這個屬性是理解JavaScript類和繼承的重要基礎。

constructor屬性始終指向創建當前對象的構造函數。比如下面例子:

  1. // 等價于 var foo = new Array(1, 56, 34, 12);  
  2. var arr = [1563412];  
  3. console.log(arr.constructor === Array); // true  
  4. // 等價于 var foo = new Function();  
  5. var Foo = function() { };  
  6. console.log(Foo.constructor === Function); // true  
  7. // 由構造函數實例化一個obj對象  
  8. var obj = new Foo();  
  9. console.log(obj.constructor === Foo); // true  
  10.  
  11. // 將上面兩段代碼合起來,就得到下面的結論  
  12. console.log(obj.constructor.constructor === Function); // true 

但是當constructor遇到prototype時,有趣的事情就發生了。

我們知道每個函數都有一個默認的屬性prototype,而這個prototype的constructor默認指向這個函數。如下例所示:

  1. function Person(name) {  
  2.     this.name = name;  
  3. };  
  4. Person.prototype.getName = function() {  
  5.     return this.name;  
  6. };  
  7. var p = new Person("ZhangSan");  
  8.  
  9. console.log(p.constructor === Person);  // true  
  10. console.log(Person.prototype.constructor === Person); // true  
  11. // 將上兩行代碼合并就得到如下結果  
  12. console.log(p.constructor.prototype.constructor === Person); // true 

當時當我們重新定義函數的prototype時(注意:和上例的區別,這里不是修改而是覆蓋),constructor屬性的行為就有點奇怪了,如下示例:

  1. function Person(name) {  
  2.     this.name = name;  
  3. };  
  4. Person.prototype = {  
  5.     getName: function() {  
  6.         return this.name;  
  7.     }  
  8. };  
  9. var p = new Person("ZhangSan");  
  10. console.log(p.constructor === Person);  // false  
  11. console.log(Person.prototype.constructor === Person); // false  
  12. console.log(p.constructor.prototype.constructor === Person); // false 

為什么呢?

原來是因為覆蓋Person.prototype時,等價于進行如下代碼操作:

  1. Person.prototype = new Object({  
  2.     getName: function() {  
  3.         return this.name;  
  4.     }  
  5. }); 

而constructor屬性始終指向創建自身的構造函數,所以此時Person.prototype.constructor === Object,即是:

  1. function Person(name) {  
  2.     this.name = name;  
  3. };  
  4. Person.prototype = {  
  5.     getName: function() {  
  6.         return this.name;  
  7.     }  
  8. };  
  9. var p = new Person("ZhangSan");  
  10. console.log(p.constructor === Object);  // true  
  11. console.log(Person.prototype.constructor === Object); // true  
  12. console.log(p.constructor.prototype.constructor === Object); // true 

怎么修正這種問題呢?方法也很簡單,重新覆蓋Person.prototype.constructor即可:

  1. function Person(name) {  
  2.     this.name = name;  
  3. };  
  4. Person.prototype = new Object({  
  5.     getName: function() {  
  6.         return this.name;  
  7.     }  
  8. });  
  9. Person.prototype.constructor = Person;  
  10. var p = new Person("ZhangSan");  
  11. console.log(p.constructor === Person);  // true  
  12. console.log(Person.prototype.constructor === Person); // true  
  13. console.log(p.constructor.prototype.constructor === Person); // true 

【編輯推薦】

  1. JavaScript類和繼承:prototype屬性
  2. JavaScript類和繼承:this屬性
  3. ExtJS Grid Tooltip的3+1種實現方式總結
  4. JavaScript異步調用框架的鏈式實現
  5. JavaScript異步調用框架的jQuery風格鏈式調用
責任編輯:yangsai 來源: 博客園
相關推薦

2009-07-08 17:42:26

this屬性

2009-07-08 17:48:18

prototype屬性

2011-05-25 16:23:35

Javascript類繼承

2009-01-04 09:08:30

面向對象繼承接口

2011-08-31 14:48:33

JavaScript

2012-02-14 09:45:02

JavaScript

2012-11-08 10:40:47

JavaScript原型鏈

2017-07-21 09:40:35

Python類、繼承和多態

2011-07-08 10:25:55

JavaScript

2009-09-09 11:28:40

Scala類

2011-07-07 13:39:14

Cocoa 框架

2011-08-24 13:56:27

JavaScript

2021-12-04 11:17:32

Javascript繼承編程

2011-03-10 14:19:56

JavaScript

2023-10-18 16:30:50

2010-09-09 09:16:27

JavaScriptdiv

2021-12-09 10:51:47

Go繼承

2023-09-27 23:28:28

Python編程

2020-04-28 10:05:33

JavaScript繼承前端

2016-12-27 09:10:29

JavaScript原型鏈繼承
點贊
收藏

51CTO技術棧公眾號

久久久美女艺术照精彩视频福利播放| 91在线视频播放地址| 日本一区二区不卡| blacked蜜桃精品一区| 17婷婷久久www| 精品国产一区二区三区| 国产精品一区二区电影| 国产劲爆久久| 国内精品久久久久久影视8| 大陆精大陆国产国语精品| 欧美大片在线看免费观看| 成人性教育av免费网址| 欧美成人午夜免费视在线看片| 四虎在线精品| 亚洲免费网站| 国产精品一区视频| 欧美激情第二页| 欧美日韩在线播放一区二区| 国产视频一区三区| 欧美激情导航| 奇米四色…亚洲| 九九久久九九久久| 日本一区二区视频在线观看| 天堂影视av| 亚洲国产精品va在看黑人| 欧美高清hd| 亚洲欧洲一二三| 欧美特级www| 在这里有精品| 成人在线免费观看网址| 欧美一区二区三区视频在线观看| 国产wwww| 亚洲资源在线观看| 日本1级在线| 欧美亚洲动漫制服丝袜| 新版中文在线官网| 亚洲天堂av网| 久久男人av| 九色91国产| 久久女同互慰一区二区三区| 在线国产福利网站| 日韩成人一区二区三区在线观看| 日本中文字幕网址| 国产精品三级| 日韩在线三区| 欧美激情中文不卡| 美丽的姑娘在线观看免费动漫| 欧美一区二区高清| av综合网站| 视频一区视频二区视频三区高| 成人免费高清在线| 91高清在线| 久久久视频在线| 日韩电影在线一区| 日本视频三区| 精品亚洲一区二区三区四区五区| 免费短视频成人日韩| 在线观看欧美激情| 狠狠躁天天躁日日躁欧美| 国产福利亚洲| 精品国产综合| 亚洲一区在线观看网站| 亚洲成人高清| 成人在线观看毛片| 欧美一区永久视频免费观看| 欧洲三级视频| 男人的天堂日韩| 亚洲欧美综合另类中字| 久久中文在线| sese一区| 欧美一区二区三区四区在线观看地址 | 日韩视频久久| 制服黑丝国产在线| 97免费中文视频在线观看| 韩日精品视频一区| 午夜伦全在线观看| 国产成人精品福利一区二区三区| 精品久久久久久亚洲精品| 久久动漫网址| 国产一二三区av| 26uuu另类亚洲欧美日本老年| 91色乱码一区二区三区| www.久久.com| 男人插女人下面免费视频| 97视频在线观看成人| 亚洲国产电影在线观看| 欧美aaaaaaaa牛牛影院| 91欧洲在线视精品在亚洲| 5566日本婷婷色中文字幕97| 一区二区三区精品久久久| 99视频精品全部免费在线视频| 丝袜美腿美女被狂躁在线观看| 日韩欧美亚洲日产国| 亚洲精品美女免费| 成人在线二区| 成人精品在线观看| 亚洲第一av在线| 91免费观看在线| 日本天堂一区| 成码无人av片在线观看网站| 国产精品夜夜夜爽张柏芝| www.午夜精品| 午夜精品久久久久久久久久| 成人在线一区| 91精品xxx在线观看| 97超碰在线资源站| 国产一区精品视频| 久久艳片www.17c.com| 亚洲免费伊人电影| 美女爽到呻吟久久久久| 成人av在线播放| 深夜福利在线观看直播| 2022亚洲天堂| 免费国产在线精品一区二区三区| 精品无人国产偷自产在线| 中文字幕日韩一区| 狠狠色丁香婷婷综合| 亚洲网色网站| 国产精品视频一区二区三区| 国产cdts系列另类在线观看| а√最新版在线天堂| 欧美一级视频在线播放| 久久av一区二区三区亚洲| 国产伦精品一区二区三区精品视频| 亚洲成人黄色网址| 日本韩国精品在线| 最新不卡av在线| 韩国v欧美v亚洲v日本v| 精品三级av| 老色鬼在线视频| av在线免费一区| 91传媒视频在线播放| 韩国一区二区三区视频| 91黑丝在线| 欧美午夜精品久久久久久蜜| 中文字幕在线看视频国产欧美在线看完整| 日韩有码免费视频| 5g国产欧美日韩视频| 色婷婷久久一区二区| 欧美自拍偷拍一区| 26uuu国产日韩综合| 国产欧美亚洲一区| 欧洲福利电影| 啪啪亚洲精品| jvid一区二区三区| 丝袜中文在线| 香蕉97视频观看在线观看| 成人淫片免费视频95视频| 亚洲中文字幕无码中文字| 亚洲一卡二卡三卡| 视频一区亚洲| 欧美这里只有精品| 欧美黑人经典片免费观看| 制服诱惑一区| 国产无套内射久久久国产| a天堂资源在线观看| 国产日韩欧美精品在线观看| 亚洲资源视频| 国产一区二区不卡视频| 日韩视频精品| 一区二区视频国产| 免费不卡av在线| 欧美日韩二三区| 一道本视频在线观看| 中文av一区二区三区| 麻豆电影在线观看| 日本大臀精品| h片在线免费| 韩国精品主播一区二区在线观看| 色综合视频一区二区三区日韩| 奇米影视777在线欧美电影观看| 日韩欧美美女在线观看| 国产精品久久久乱弄| 免费观看日韩av| 国产亚洲欧美日韩俺去了| 亚洲图片自拍偷拍| 精品av综合导航| 91国产美女在线观看| 亚洲一区二区三区视频播放| 亚洲国产一区二区在线| 日韩欧美xxxx| 热久久最新网址| 国产v综合ⅴ日韩v欧美大片| 亚洲最大的av网站| 人妻av中文系列| 最新版sss视频在线| 青春草在线视频| 国产成人夜色高潮福利影视| 青青青青在线视频| **孕交吃奶水一级毛片| 午夜不卡视频| 人妖一区二区三区| 麻豆一区二区三| 欧美日韩亚洲国产综合| 这里只有精品丝袜| 亚洲成人a**址| av在线播放国产| 欧洲乱码伦视频免费| 激情综合色播激情啊| 欧美群妇大交群中文字幕|