成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

JavaScript類和繼承:constructor屬性

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

constructor屬性始終指向創(chuàng)建當(dāng)前對象的構(gòu)造函數(shù)。比如下面例子:

  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. // 由構(gòu)造函數(shù)實例化一個obj對象  
  8. var obj = new Foo();  
  9. console.log(obj.constructor === Foo); // true  
  10.  
  11. // 將上面兩段代碼合起來,就得到下面的結(jié)論  
  12. console.log(obj.constructor.constructor === Function); // true 

但是當(dāng)constructor遇到prototype時,有趣的事情就發(fā)生了。

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

  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. // 將上兩行代碼合并就得到如下結(jié)果  
  12. console.log(p.constructor.prototype.constructor === Person); // true 

當(dāng)時當(dāng)我們重新定義函數(shù)的prototype時(注意:和上例的區(qū)別,這里不是修改而是覆蓋),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屬性始終指向創(chuàng)建自身的構(gòu)造函數(shù),所以此時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種實現(xiàn)方式總結(jié)
  4. JavaScript異步調(diào)用框架的鏈式實現(xiàn)
  5. JavaScript異步調(diào)用框架的jQuery風(fēng)格鏈式調(diào)用
責(zé)任編輯:yangsai 來源: 博客園
相關(guān)推薦

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

面向?qū)ο?/a>繼承接口

2011-08-31 14:48:33

JavaScript

2012-02-14 09:45:02

JavaScript

2017-07-21 09:40:35

Python類、繼承和多態(tài)

2012-11-08 10:40:47

JavaScript原型鏈

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

2011-03-10 14:19:56

JavaScript

2021-12-04 11:17:32

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編程

2013-09-18 14:01:46

JavaScript

2020-04-28 10:05:33

JavaScript繼承前端
點贊
收藏

51CTO技術(shù)棧公眾號

主站蜘蛛池模板: 亚洲欧美一区二区三区国产精品 | 成人综合视频在线观看 | 九九免费观看视频 | 成人性视频免费网站 | 九九综合九九 | 手机av免费在线 | 可以在线看的黄色网址 | 成人精品一区亚洲午夜久久久 | 亚洲欧美自拍偷拍视频 | 国产精品久久久久久久久久久新郎 | 中文字幕av网站 | 精品综合久久 | 欧美日韩在线一区二区三区 | www.日本国产 | 亚洲午夜精品 | 亚洲国产精品一区 | 欧美中文字幕一区二区三区亚洲 | 在线观看av网站 | 日韩a | 蜜桃特黄a∨片免费观看 | 日韩在线观看网站 | 一级片成人 | 精品日韩电影 | 亚洲成人免费视频 | 欧美一区精品 | 日韩一级免费看 | 国产精品久久九九 | 国产黄色大片在线免费观看 | 日韩欧美视频网站 | 日本一区二区三区在线观看 | 免费亚洲成人 | 日韩一区二区三区在线看 | 国产 91 视频| 精品国产高清一区二区三区 | 精品国产一区二区国模嫣然 | 毛片1| 日韩免费在线 | 久草欧美 | 日韩有码在线观看 | 亚洲精品福利在线 | 国产中文在线观看 |