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

公司主營業(yè)務:成都網站制作、成都網站建設、外貿營銷網站建設、移動網站開發(fā)等業(yè)務。幫助企業(yè)客戶真正實現(xiàn)互聯(lián)網宣傳,提高企業(yè)的競爭能力。成都創(chuàng)新互聯(lián)是一支青春激揚、勤奮敬業(yè)、活力青春激揚、勤奮敬業(yè)、活力澎湃、和諧高效的團隊。公司秉承以“開放、自由、嚴謹、自律”為核心的企業(yè)文化,感謝他們對我們的高要求,感謝他們從不同領域給我們帶來的挑戰(zhàn),讓我們激情的團隊有機會用頭腦與智慧不斷的給客戶帶來驚喜。成都創(chuàng)新互聯(lián)推出兩當免費做網站回饋大家。
如果這個函數被用在創(chuàng)建自定義對象的場景中,我們稱這個函數為構造函數。 比如下面一個簡單的場景:
- // 構造函數
- function Person(name) {
- this.name = name;
- }
- // 定義Person的原型,原型中的屬性可以被自定義對象引用
- Person.prototype = {
- getName: function() {
- return this.name;
- }
- }
- var zhang = new Person("ZhangSan");
- console.log(zhang.getName()); // "ZhangSan"
作為類比,我們考慮下JavaScript中的數據類型 - 字符串(String)、數字(Number)、數組(Array)、對象(Object)、日期(Date)等。 我們有理由相信,在JavaScript內部這些類型都是作為構造函數來實現(xiàn)的,比如:
- // 定義數組的構造函數,作為JavaScript的一種預定義類型
- function Array() {
- // ...
- }
- // 初始化數組的實例
- var arr1 = new Array(1, 56, 34, 12);
- // 但是,我們更傾向于如下的語法定義:
- var arr2 = [1, 56, 34, 12];
同時對數組操作的很多方法(比如concat、join、push)應該也是在prototype屬性中定義的。
實際上,JavaScript所有的固有數據類型都具有只讀的prototype屬性(這是可以理解的:因為如果修改了這些類型的prototype屬性,則哪些預定義的方法就消失了), 但是我們可以向其中添加自己的擴展方法。
- // 向JavaScript固有類型Array擴展一個獲取最小值的方法
- Array.prototype.min = function() {
- var min = this[0];
- for (var i = 1; i < this.length; i++) {
- if (this[i] < min) {
- min = this[i];
- }
- }
- return min;
- };
- // 在任意Array的實例上調用min方法
- console.log([1, 56, 34, 12].min()); // 1
注意:這里有一個陷阱,向Array的原型中添加擴展方法后,當使用for-in循環(huán)數組時,這個擴展方法也會被循環(huán)出來。
下面的代碼說明這一點(假設已經向Array的原型中擴展了min方法):
- var arr = [1, 56, 34, 12];
- var total = 0;
- for (var i in arr) {
- total += parseInt(arr[i], 10);
- }
- console.log(total); // NaN
解決方法也很簡單:
- var arr = [1, 56, 34, 12];
- var total = 0;
- for (var i in arr) {
- if (arr.hasOwnProperty(i)) {
- total += parseInt(arr[i], 10);
- }
- }
- console.log(total); // 103
網站欄目:JavaScript類和繼承:prototype屬性
文章鏈接:http://m.fisionsoft.com.cn/article/cocoeoj.html


咨詢
建站咨詢
