最近2018中文字幕在日韩欧美国产成人片_国产日韩精品一区二区在线_在线观看成年美女黄网色视频_国产精品一区三区五区_国产精彩刺激乱对白_看黄色黄大色黄片免费_人人超碰自拍cao_国产高清av在线_亚洲精品电影av_日韩美女尤物视频网站

RELATEED CONSULTING
相關咨詢
選擇下列產(chǎn)品馬上在線溝通
服務時間:8:30-17:00
你可能遇到了下面的問題
關閉右側工具欄

新聞中心

這里有您想知道的互聯(lián)網(wǎng)營銷解決方案
js中創(chuàng)建對象的幾種方式

前言

成都創(chuàng)新互聯(lián)公司專注于景泰網(wǎng)站建設服務及定制,我們擁有豐富的企業(yè)做網(wǎng)站經(jīng)驗。 熱誠為您提供景泰營銷型網(wǎng)站建設,景泰網(wǎng)站制作、景泰網(wǎng)頁設計、景泰網(wǎng)站官網(wǎng)定制、成都微信小程序服務,打造景泰網(wǎng)絡公司原創(chuàng)品牌,更為您提供景泰網(wǎng)站排名全網(wǎng)營銷落地服務。

不管是哪門語言,千變?nèi)f化不離其宗,深入理解其本質(zhì),方能應用自如。對應到js,閉包,原型,函數(shù),對象等是需要花費大功夫思考、理解的。本文穿插了js原型和函數(shù)的相關知識,討論了批量創(chuàng)建對象的幾種方式以及它們的優(yōu)缺點。

正文

說起創(chuàng)建對象,最容易想到的便是通過對象字面量方式直接定義一個對象吧,但這種方式只能創(chuàng)建少量,單獨且相互間無聯(lián)系的對象。若要批量創(chuàng)建對象,該如何?

工廠模式

工廠模式非常直觀,將創(chuàng)建對象的過程抽象為一個函數(shù),用函數(shù)封裝以特定接口創(chuàng)建對象的細節(jié)。如下所示:

function createStudent(name,sex,grade){       
 var o = new Object();
 o.name = name;
 o.sex = sex;
 o.grade = grade;

 o.sayName = function(){
 console.log(this.name);
 }
 return o;
}
var s1 = createStudent('Claiyre','famale',1);

通俗地講,工廠模式就是將創(chuàng)建對象的語句放在一個函數(shù)里,通過傳入?yún)?shù)來創(chuàng)建特定對象,最后返回創(chuàng)建的對象。

工廠模式雖然可以創(chuàng)建多個相似的對象,但卻不能解決對象標識的問題,即怎樣知道一個對象的類型。構造函數(shù)模式應運而生。

構造函數(shù)模式

構造函數(shù)模式是java語言創(chuàng)建對象的通用方式。兩種語言用構造函數(shù)創(chuàng)建對象的方式略有不同,注意區(qū)別。

在JavaScript中沒有類的概念,函數(shù)即為一等公民,因此,不必顯式聲明某個類,直接創(chuàng)建構造函數(shù)即可,類的方法和屬性在構造函數(shù)中(或原型對象上)處理。構造函數(shù)模式的示例代碼如下:

function Student(name,sex,grade){       
 this.name = name;
 this.sex = sex;
 this.grade = grade;
 this.sayName = function(){
 console.log(this.name);
 }
}
var s2 = new Student('孫悟空','male',2);

細心的朋友一定發(fā)現(xiàn)了構造函數(shù)的函數(shù)名首字母是大寫的,而普通函數(shù)首字母則是小寫,這是眾多OO語言約定俗成的規(guī)定,雖然大多數(shù)情況下不大寫也不會報錯,但是為了代碼的規(guī)范性和可讀性,還是應該將構造函數(shù)的首字母大寫,與普通函數(shù)區(qū)別開。

與工廠模式相比,用構造模式創(chuàng)建對象有以下幾點不同:

  • 沒有顯示地創(chuàng)建對象
  • 直接將屬性和方法賦給this對象
  • 沒有return語句

此外,還應注意到要創(chuàng)建Student的實例,必須要使用new操作符,創(chuàng)建的實例對象將有一個constructor(構造器)屬性,指向Person構造函數(shù)。調(diào)用構造函數(shù)創(chuàng)建對象經(jīng)過了以下幾個過程:

  • 創(chuàng)建一個新對象
  • 將構造函數(shù)的作用域賦給新對象(因此this就指向了這個新對象)
  • 執(zhí)行構造函數(shù)中的代碼
  • 返回新對象(不需要顯式返回)

構造函數(shù)雖好用,但也不是沒有缺點。使用構造函數(shù)的主要問題是:每個方法都要在每個實例上創(chuàng)建一遍。在ECMAScript中,函數(shù)即對象,因此每定義一個函數(shù),也就是實例化了一個對象。下面的例子證明了這個缺點。

var s3 = new Student('唐僧','male',3);
var s4 = new Student('白骨精','female',4);
s3.sayName();
s4.sayName();
console.log(s3.sayName == s4.sayName);

運行結果:

js中創(chuàng)建對象的幾種方式

也就是說通過構造函數(shù)實例化的多個對象的方法,是多個不同的方法,但它們內(nèi)部的代碼以及實現(xiàn)的功能是相同的,這就造成了一定的資源浪費。

幸運的是,這個問題可以用原型模式來解決。

原型模式

js中,每個函數(shù)都有一個prototype屬性,它是一個指針,指向一個對象,叫做原型對象,原型對象包含了可以由特定類型的所有實例對象共享的屬性和方法。此外,這個對象有一個與生自來的屬性constructor,指向創(chuàng)建對象的構造方法。

使用原型模式可以讓所有的實例共享原型對象中的屬性和方法,也就是說,不必再構造函數(shù)中定義對象實例的信息。用代碼表示如下:

function Student_1(){
}
Student_1.prototype.name = 'Claiyre';
Student_1.prototype.sex = 'female';
Student_1.prototype.class = 5;
Student_1.prototype.sayName = function (){
 console.log(this.name);
}
var s5 = new Student_1();       s5.sayName(); //Claiyre
var s6 = new Student_1();
s6.sayName(); //Claiyre

一張圖勝過千言萬語,下圖清楚地闡釋了各個對象和原型對象間的關系:

js中創(chuàng)建對象的幾種方式

了解過原型后,可以繼續(xù)在實例對象上增添屬性或方法:

s6.name = 'John';      
s6.sayName(); //John

當要讀取某個對象的屬性時,都會執(zhí)行一次搜索,搜索首先從對象實例本身開始,如果在實例中找到了這個屬性,則搜索結束,返回實例屬性的值;若實例上沒有找到,則繼續(xù)向?qū)ο蟮脑蛯ο笱由欤阉鲗ο蟮脑蛯ο?,若在原型對象上找到了,則返回原型上相應屬性的值,若沒有找到,則返回undefined。因此,實例對象屬性會覆蓋原型對象上的同名屬性,所以上面第二行代碼輸出的是John。

  • Object.getPrototypeOf(object)方法返回參數(shù)對象的原型對象。
  • Object.keys(object)方法返回對象上課枚舉的實例屬性。

原型中的所有屬性都是被所有實例所共享的,這種共享對于函數(shù)來說非常合適,對于包含基本值的屬性也說的過去(實例屬性會覆蓋原型同名屬性),但對于那些包含引用類型的屬性,可有大麻煩了

Student_1.prototype.friends = ['aa','bb'];
console.log('s6的朋友' + s6.friends);
s5.friends.push('cc');
console.log('s5的朋友' + s5.friends);
console.log('s6的朋友' + s6.friends);

運行結果:

js中創(chuàng)建對象的幾種方式

問題來了,我們只想改變s5的朋友列表,但由于原型模式的共享本質(zhì),s6的朋友列表也隨之改變了。

因此,很少單獨使用原型模式。

組合使用構造函數(shù)和原型模式

構造函數(shù)模式用于定義實例屬性,原型模式則用于定義方法和共享的屬性。這種混合模式不僅支持向構造函數(shù)傳入?yún)?shù),還最大限度地節(jié)約了內(nèi)存,可謂是集兩模式之長。示例代碼如下:

function Student(name,sex,grade){       
 this.name = name;
 this.sex = sex;
 this.grade = grade;
}
Student.prototype.sayName = function(){
 console.log(this.name);
}
Student.prototype.school = 'Joooh school';

其他模式

除了以上幾種常見的模式外,批量創(chuàng)建對象的方式還有

  • 動態(tài)原型模式:僅在第一次調(diào)用構造函數(shù)時,將方法賦給原型對象的相應屬性,其他示例的處理方式同構造函數(shù)模式
  • 寄生構造函數(shù)模式:僅僅封裝創(chuàng)建對象的代碼,然后再返回新創(chuàng)建的對象,仍使用new操作符調(diào)用
  • 穩(wěn)妥構造函數(shù)模式:沒有公共屬性,只有私有變量和方法,以及一些get/set方法,用以處理私有變量。

結語

每種模式都有各自的優(yōu)缺點,具體要使用哪種,還需結合實際場景,深入理解,靈活運用。

以上就是本文的全部內(nèi)容,希望本文的內(nèi)容對大家的學習或者工作能帶來一定的幫助,同時也希望多多支持創(chuàng)新互聯(lián)!


當前題目:js中創(chuàng)建對象的幾種方式
文章網(wǎng)址:http://fisionsoft.com.cn/article/iedoji.html