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

首頁 > 語言 > JavaScript > 正文

javascript 寫類方式之一

2024-05-06 14:14:57
字體:
來源:轉載
供稿:網友
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那么緊湊。但的確可以減少內存的消耗。
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表

圖片精選

主站蜘蛛池模板: 淄博市| 临泉县| 汝南县| 台南县| 永登县| 灌云县| 贺兰县| 天水市| 岫岩| 武山县| 无为县| 桂东县| 西乌| 嘉义市| 郎溪县| 来安县| 唐山市| 东乌| 呼和浩特市| 青冈县| 盈江县| 兴化市| 林甸县| 韩城市| 延长县| 精河县| 眉山市| 阳信县| 肇州县| 康乐县| 杭锦旗| 莫力| 肇源县| 莱州市| 高台县| 阿尔山市| 鹤壁市| 那坡县| 横山县| 游戏| 长治县|