国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > JavaScript > 正文

javascript 寫類方式之一

2019-11-21 01:17:40
字體:
來源:轉載
供稿:網友
EMCA262規范中沒有類(class)的概念,js的new只是讓他看起來更像c++,java一點。這里說的寫類,只是書寫js代碼風格而已。
1、構造函數方式
復制代碼 代碼如下:

/**
* Person類:定義一個人,有個屬性name,和一個getName方法
* @param {String} name
*/
function Person(name) {
this.name = name;
this.getName = function() {
return this.name;
}
}

這種風格讓我們這些寫過java的有點親切在于構造一個對象需要配置一些參數,參數要賦值給類里面this。但與java的區別是js用function來定義類,參數也無需定義類型。

類寫好了,我們造幾個對象:
復制代碼 代碼如下:

var p1 = new Person("Jack");
var p2 = new Person("Tom");
console.log(p1 instanceof Person);//true
console.log(p2 instanceof Person);//true

控制臺輸出也證明了p1,p2的確是類Person的對象實例。

這種方式的優點是:可以根據參數來構造不同的對象實例 ,缺點是構造時每個實例對象都會生成getName方法版本,造成了內存的浪費 。

當然經驗豐富的程序員用一個外部函數來代替類方法,達到了每個對象共享同一個方法。改寫后的類如下:
復制代碼 代碼如下:

//外部函數
function getName() {
return this.name;
}

function Person(name) {
this.name = name;
this.getName = getName;//注意這里
}

呵呵,有人可能覺得代碼風格有點差強人意,怎么看也沒有java那么緊湊。但的確可以減少內存的消耗。
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 连南| 威信县| 贵阳市| 达孜县| 稻城县| 磴口县| 丹巴县| 奎屯市| 延川县| 建宁县| 凌云县| 屏边| 如皋市| 吉林省| 张北县| 景德镇市| 澄迈县| 兴宁市| 周宁县| 库伦旗| 慈溪市| 灵丘县| 峨眉山市| 康平县| 虞城县| 宁夏| 镇原县| 永州市| 根河市| 武川县| 东安县| 台北县| 洱源县| 宜黄县| 甘孜县| 同江市| 彭阳县| 乳山市| 塔河县| 门源| 陆川县|