一区二区久久-一区二区三区www-一区二区三区久久-一区二区三区久久精品-麻豆国产一区二区在线观看-麻豆国产视频

慎用 somefunction.prototype 分析

復制代碼 代碼如下:
// code from jb51.NET
function Person(name) {
this.Name = name;
}
Person.prototype.SayHello = function() {
alert('Hello, ' + this.Name);
}
Person.prototype.SayBye = function() {
alert('Goodbye, ' + this.Name);
}

不過,有的時候,為了書寫以及維護的方便,我們會把公有方法的聲明寫到一個對象里,然后賦值給 Person.prototype,例如:
復制代碼 代碼如下:
// code from jb51.NET
function Person(name) {
this.Name = name;
}
Person.prototype = {
SayHello: function() {
alert('Hello, ' + this.Name);
},
SayBye: function() {
alert('Goodbye, ' + this.Name);
}
}

使用這種方式,在這個類具有大量公有方法的時候,就不需要維護許多的 Person 標識符,如果某一天這個類的名字需要改變,那么要改的地方只有兩個,一個是 function 的聲明,一個是 prototype 前面的標識符,如果是使用前一種方式的話,那么有多少個公有方法,就需要維護 N+1 個標識符了,雖然可以使用查找替換,但是從穩定上來說,查找替換可能會引起一些錯誤,這增加了維護的成本。

這種方式雖然給我們的維護增加了便利,但也引發了另外一個隱藏的問題,就是類的 constructor 屬性丟失的問題。
復制代碼 代碼如下:
// code from jb51.NET
function Person1(name) {
this.Name = name;
}
Person1.prototype.SayHello = function() {
alert('Hello, ' + this.Name);
}
Person1.prototype.SayBye = function() {
alert('Goodbye, ' + this.Name);
}
// code from jb51.NET
function Person2(name) {
this.Name = name;
}
Person2.prototype = {
SayHello: function() {
alert('Hello, ' + this.Name);
},
SayBye: function() {
alert('Goodbye, ' + this.Name);
}
}
alert(new Person1('Bill').constructor);
alert(new Person2('Steve').constructor);

運行上面的測試代碼我們可以發現,Person1 的 constructor 屬性為 Person1 類的構造函數,但是 Person2 的 constructor 屬性卻是 Object,那么在需要使用 constructor 屬性來判斷對象類型的時候,就會出現問題。
因此,在寫 JavaScript 類的時候,如果不需要使用 constructor 屬性來獲取對象的類型,那么個人比較傾向于使用第二種寫法,但是如果需要使用 constructor 屬性以實現自己的反射機制或 GetType 函數等等,那么就要使用第一種寫法。
當然,如果在實現自己反射機制或 GetType 函數時并不依賴 constructor 屬性,那么兩種寫法都是可以的了,例如額外維護一個成員變量,用于標識自身的類型等。也可以使用一些現成的JS框架,有一些框架已經實現了JS中類的實現等,例如 js.class,這就看個人需要進行取舍了。

JavaScript技術慎用 somefunction.prototype 分析,轉載需保留來源!

鄭重聲明:本文版權歸原作者所有,轉載文章僅為傳播更多信息之目的,如作者信息標記有誤,請第一時間聯系我們修改或刪除,多謝。

主站蜘蛛池模板: 狠狠成人| 欧美精品一国产成人性影视 | 激情文学综合 | 欧美a极品极品欧美 | 国产在线每日更新 | 羞羞色男人的天堂伊人久久 | 国产在线毛片 | 亚洲人成一区二区三区 | 亚洲欧美色视频 | 午夜国产情侣拍视频 | 草草线在成年免费视频网站 | 精品国产免费久久久久久婷婷 | 精品国产高清a毛片无毒不卡 | 久久一日本道色综合久久m 久久伊人草 | 成人福利视频网站 | 天堂在线观看 | 五月天激情久久综合一区 | 亚洲精品在线不卡 | 欧美zooz人禽交免费观看 | 视色4se成人午夜精品 | 69精品视频 | 日韩欧美成人乱码一在线 | 狠狠色噜噜狠狠狠四色米奇 | 9797在线看片亚洲精品 | 国产福利在线观看 | 国产原创麻豆 | 亚洲黄色一级毛片 | 91香蕉国产亚洲一区二区三区 | 国产岛国 | 午夜a毛片| 激情视频激情小说激情图片 | 玖玖在线国产精品 | 国产精品29页 | 6080yy午夜不卡一二三区久久 | 中文字幕亚洲一区二区va在线 | 91精品全国免费观看含羞草 | 国产日韩91 | 美女黄网站 | 色噜噜狠狠先锋影音久久 | 亚洲国产精品一区二区三区久久 | 五月丁六月停停 |