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

JavaScript類和繼承:prototype屬性

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

我們已經(jīng)在第一章中使用prototype屬性模擬類和繼承的實現(xiàn)。 prototype屬性本質(zhì)上還是一個JavaScript對象。 并且每個函數(shù)都有一個默認的prototype屬性。

如果這個函數(shù)被用在創(chuàng)建自定義對象的場景中,我們稱這個函數(shù)為構(gòu)造函數(shù)。 比如下面一個簡單的場景:

  1. // 構(gòu)造函數(shù)  
  2. function Person(name) {  
  3.     this.name = name;  
  4. }  
  5. // 定義Person的原型,原型中的屬性可以被自定義對象引用  
  6. Person.prototype = {  
  7.     getName: function() {  
  8.         return this.name;  
  9.     }  
  10. }  
  11. var zhang = new Person("ZhangSan");  
  12. console.log(zhang.getName());   // "ZhangSan" 

作為類比,我們考慮下JavaScript中的數(shù)據(jù)類型 - 字符串(String)、數(shù)字(Number)、數(shù)組(Array)、對象(Object)、日期(Date)等。 我們有理由相信,在JavaScript內(nèi)部這些類型都是作為構(gòu)造函數(shù)來實現(xiàn)的,比如:

  1. // 定義數(shù)組的構(gòu)造函數(shù),作為JavaScript的一種預定義類型  
  2. function Array() {  
  3.     // ...  
  4. }  
  5.  
  6. // 初始化數(shù)組的實例  
  7. var arr1 = new Array(1563412);  
  8. // 但是,我們更傾向于如下的語法定義:  
  9. var arr2 = [1563412]; 

同時對數(shù)組操作的很多方法(比如concat、join、push)應(yīng)該也是在prototype屬性中定義的。

實際上,JavaScript所有的固有數(shù)據(jù)類型都具有只讀的prototype屬性(這是可以理解的:因為如果修改了這些類型的prototype屬性,則哪些預定義的方法就消失了), 但是我們可以向其中添加自己的擴展方法。

  1. // 向JavaScript固有類型Array擴展一個獲取最小值的方法  
  2. Array.prototype.min = function() {  
  3.     var min = this[0];  
  4.     for (var i = 1; i <  this.length; i++) {  
  5.         if (this[i] <  min) {  
  6.             min = this[i];  
  7.         }  
  8.     }  
  9.     return min;  
  10. };  
  11.  
  12. // 在任意Array的實例上調(diào)用min方法  
  13. console.log([1563412].min());  // 1 

注意:這里有一個陷阱,向Array的原型中添加擴展方法后,當使用for-in循環(huán)數(shù)組時,這個擴展方法也會被循環(huán)出來。

下面的代碼說明這一點(假設(shè)已經(jīng)向Array的原型中擴展了min方法):

  1. var arr = [1563412];  
  2. var total = 0;  
  3. for (var i in arr) {  
  4.     total += parseInt(arr[i], 10);  
  5. }  
  6. console.log(total);   // NaN 

解決方法也很簡單:

  1. var arr = [1563412];  
  2. var total = 0;  
  3. for (var i in arr) {  
  4.     if (arr.hasOwnProperty(i)) {  
  5.         total += parseInt(arr[i], 10);  
  6.     }  
  7. }  
  8. console.log(total);   // 103 

【編輯推薦】

  1. JavaScript類和繼承:this屬性
  2. ExtJS Grid Tooltip的3+1種實現(xiàn)方式總結(jié)
  3. JavaScript異步調(diào)用框架的鏈式實現(xiàn)
  4. JavaScript異步調(diào)用框架的jQuery風格鏈式調(diào)用
  5. JavaScript異步調(diào)用框架的代碼實現(xiàn)
責任編輯:yangsai 來源: 博客園
相關(guān)推薦

2009-07-08 17:42:26

this屬性

2009-07-08 17:51:45

constructor

2017-07-27 15:05:18

前端JavaScript難點

2011-05-25 16:23:35

Javascript類繼承

2009-01-04 09:08:30

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

2023-05-30 15:06:21

JavaScript屬性開發(fā)

2016-06-07 14:28:39

Javascript原型

2012-02-14 09:45:02

JavaScript

2011-08-31 14:48:33

JavaScript

2011-07-08 10:25:55

JavaScript

2012-11-08 10:40:47

JavaScript原型鏈

2021-06-11 06:54:34

原型構(gòu)造函數(shù)

2017-07-21 09:40:35

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

2011-07-07 13:39:14

Cocoa 框架

2011-08-24 13:56:27

JavaScript

2009-09-09 11:28:40

Scala類

2010-09-09 09:16:27

JavaScriptdiv

2011-03-10 14:19:56

JavaScript

2021-12-04 11:17:32

Javascript繼承編程

2023-10-18 16:30:50

點贊
收藏

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

主站蜘蛛池模板: 午夜寂寞影院列表 | 男女羞羞的网站 | 亚洲精品一 | 中文字幕 国产精品 | 91精品国产91久久久久福利 | 日韩精品一区二区三区久久 | 99精品免费| 色视频一区二区 | 夜夜草| 久久久久久久一区 | 国产在线观看一区二区 | 中文字幕视频在线观看 | 亚洲婷婷六月天 | 国产中文一区二区三区 | 日韩成人专区 | 精品美女视频在免费观看 | 日韩视频二区 | 人碰人操 | 日本中文在线 | 免费视频成人国产精品网站 | 爱草在线| 国产精品99免费视频 | 国产专区免费 | 黄色片网站在线观看 | 午夜伦理影院 | 久久久久久久av | 久久这里有精品 | 日韩精品1区2区3区 成人黄页在线观看 | 高清国产一区二区 | 在线观看亚洲欧美 | 成人在线免费视频观看 | 欧美一区二区三区视频 | 亚洲精品国产电影 | 干干干日日日 | 成人精品一区 | 亚洲高清在线免费观看 | 日韩在线观看 | 91精品导航 | 日本久草视频 | av看片| 9久久精品 |