詳細(xì)分析Javascript中創(chuàng)建對象的四種方式
前言
使用Javascript創(chuàng)建對象的方式有很多,現(xiàn)在就來列舉一下其中的四種方式,并且羅列出了每種方式的優(yōu)缺點,可以讓大家進(jìn)行選擇使用,下面來看看。
工廠模式
function createPerson(name, age){
var obj = new Object();
obj.name = name;
obj.age = age;
return obj; //一定要返回,否則打印undefined:undefined
}
var person1 = new createPerson('Young',18);
console.log(person1.name + ':' + person1.age);
優(yōu)點:工廠模式可以解決創(chuàng)建多個相似對象
缺點:沒有解決對象識別問題(怎樣確定一個對象的類型)
構(gòu)造函數(shù)模式
function Person(name,age){
this.name = name;
this.age = age;
}
var person1 = new Person('Young',18);
console.log(person1.name + ':' + person1.age);
在說優(yōu)缺點之前,先來說說她本身的一點小故事吧
將構(gòu)造函數(shù)當(dāng)做函數(shù)使用
function Person(name,age){
this.name=name;
this.age=age;
this.sayName=function(){
return this.name;
}
}
//當(dāng)做構(gòu)造函數(shù)使用
var person1 = new Person('Young', 18);
person1.sayName();
console.log(person1.name + ':' + person1.age);
//當(dāng)做普通函數(shù)調(diào)用
Person('Wind', 18);
console.log(window.sayName());
//在另一個作用域中調(diào)用
var obj = new Object();
Person.call(obj, 'bird', 100);
console.log(obj.sayName());
構(gòu)造函數(shù)優(yōu)缺點
優(yōu)點:可以將它的實例標(biāo)識為一種特定類型
缺點:每個方法都要在每個實例上重新創(chuàng)建一遍。當(dāng)然你也可以這樣改:
function Person(name, age){
this.name = name;
this.age = age;
this.sayName = sayName;
}
function sayName(){
return this.name;
}
改為調(diào)用全局函數(shù),這樣一來毫無封裝性可言。。。接下來的原型模式可以彌補這個的不足
原型模式
function Person(){
}
Person.prototype.name = 'Young';
Person.prototype.age = 18;
Person.prototype.sayName = function(){
return this.name;
}
var person1 = new Person();
console.log(person1.sayName());
var person2 = new Person();
console.log(person1.sayName());
alert(person1.sayName === person2.sayName);
//person1和person2訪問的是同一組屬性的同一個sayName()函數(shù)
雖然可以通過對象實例訪問保存在原型中的值,但卻不能通過實例對象重寫原型中的值
function Person(){
}
Person.prototype.name='Young';
Person.prototype.age=18;
Person.prototype.sayName=function(){
return this.name;
}
var person1=new Person();
var person2=new Person();
person1.name='Wind';
console.log(person1.sayName());//Wind
console.log(person2.sayName());//Young
alert(person1.sayName==person2.sayName);//true
在我們調(diào)用person1.sayName的時候,會先后執(zhí)行兩次搜索,解析器先確定實例person1是否有sayName的屬性,有則調(diào)用自己的屬性,沒有則搜索原型中的屬性。
function Person(){
}
Person.prototype.name='Young';
Person.prototype.age=18;
Person.prototype.sayName=function(){
return this.name;
}
var person1=new Person();
var person2=new Person();
person1.name='Wind';
console.log(person1.sayName());//Wind
console.log(person2.sayName());//Young
delete person1.name;
console.log(person1.sayName());//Young
console.log(person2.sayName());//Young
使用hasOwnPropertyType方法可以檢測一個屬性是存在與原型中還是存在于實例中,該方法是從Object繼承來的,實例中為true,原型中為false。
枚舉對象上的實例屬性用Object.keys()方法
function Person(){
}
Person.prototype.name='Young';
Person.prototype.age=18;
Person.prototype.sayName=function(){
return this.name;
}
var keys=Object.keys(Person.prototype);
console.log(keys);//["name", "age", "sayName"]
原型模式優(yōu)缺點
優(yōu)點:不用每個方法都要在每個實例上重申一遍
缺點:很少有人單獨使用原型模式地。。問題詳列
function Person(){
}
Person.prototype={
constructor:Person,
name:'Young',
age:18,
friends:['Big','Pig'],
sayName:function(){
return this.name;
}
};
var p1=new Person();
var p2=new Person();
p1.friends.push('Mon');
console.log(p1.friends);//["Big", "Pig", "Mon"]
console.log(p2.friends);//["Big", "Pig", "Mon"]
正是因為實例一般都要有自己的屬性,而我們這里將他放在了Person.prototype中,所以隨著p1的修改,整個實例包括原型都修改了。那么,我們可以組合使用構(gòu)造函數(shù)模式和原型模式。
組合使用構(gòu)造函數(shù)模式和原型模式
function Person(name,age){
this.name=name;
this.age=age;
this.friends=['Big','Pig'];
}
Person.prototype={
sayName:function(){
return this.name;
}
};
var p1=new Person('Young',18);
var p2=new Person('Wind',78);
p1.friends.push('Raganya');
console.log(p1.friends);//["Big", "Pig", "Raganya"]
console.log(p2.friends);//["Big", "Pig"]
console.log(p1.friends==p2.friends);//false
console.log(p1.sayName==p2.sayName);//true
這種模式是目前使用最廣泛、認(rèn)同度最高的一種創(chuàng)建自定義類型的方法。是用來定義引用類型的一種默認(rèn)模式。
總結(jié)
以上就是關(guān)于分析Javascript中創(chuàng)建對象方式的全部內(nèi)容,通過這篇文章為大家總結(jié)的四種方式和其優(yōu)缺點,希望可以對大家學(xué)習(xí)使用Javascript能有所幫助。
- JavaScript 三種創(chuàng)建對象的方法
- JavaScript 創(chuàng)建對象
- js中創(chuàng)建對象的幾種方式示例介紹
- javascript轉(zhuǎn)換字符串為dom對象(字符串動態(tài)創(chuàng)建dom)
- js創(chuàng)建對象的幾種常用方式小結(jié)(推薦)
- Jquery通過JSON字符串創(chuàng)建JSON對象
- ajax 異步獲取數(shù)據(jù)實現(xiàn)代碼 (js創(chuàng)建ajax對象)
- Javascript創(chuàng)建自定義對象 創(chuàng)建Object實例添加屬性和方法
- js使用對象直接量創(chuàng)建對象的代碼
相關(guān)文章
微信小程序與webview?H5交互的方法(內(nèi)嵌H5跳轉(zhuǎn)原生頁面)
小程序webView中嵌套H5頁面,難免會遇到小程序與h5頁面進(jìn)行數(shù)據(jù)通信或交互的場景,下面這篇文章主要給大家介紹了關(guān)于微信小程序與webview?H5交互的相關(guān)資料,內(nèi)嵌H5跳轉(zhuǎn)原生頁面,需要的朋友可以參考下2022-11-11
javascript記錄文本框內(nèi)文字個數(shù)檢測文字個數(shù)變化
要對文本框中用戶輸入的文字進(jìn)行記數(shù),在下面顯示出來,經(jīng)研究找到個不錯的方法,可以完美解決在刪除文字后,字?jǐn)?shù)變化問題2014-10-10
JS關(guān)閉子窗口并且刷新上一個窗口的實現(xiàn)示例
這篇文章主要介紹了JS關(guān)閉子窗口并且刷新上一個窗口的實現(xiàn)示例,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2020-03-03
JS實現(xiàn)無限級網(wǎng)頁折疊菜單(類似樹形菜單)效果代碼
這篇文章主要介紹了JS實現(xiàn)無限級網(wǎng)頁折疊菜單(類似樹形菜單)效果代碼,涉及JavaScript基于鼠標(biāo)事件實現(xiàn)針對頁面元素結(jié)點的遍歷及樣式操作技巧,具有一定參考借鑒價值,需要的朋友可以參考下2015-09-09

