亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 語言 > JavaScript > 正文

詳解JavaScript基于面向對象之創建對象(2)

2024-05-06 16:26:03
字體:
來源:轉載
供稿:網友
這篇文章主要介紹了JavaScript基于面向對象之創建對象,詳細的分析面向對象的原型方式以及其他綜合的方式,感興趣的小伙伴們可以參考一下
 

接著上文《詳解JavaScript基于面向對象之創建對象(1)》繼續學習。

4、原型方式
       我們創建的每個函數都有一個通過prototype(原型)屬性,這個屬性是一個對象,它的用途是包含可以由特定類型的所有實例共享的屬性和方法。邏輯上可以這么理解:prototypt通過條用構造函數而創建的那個對象的原型對象。使用原型的好處就是可以讓所有對象實例共享它所包含的屬性和方法。也就是說,不必在構造函數中定義對象信息,而是直接將這些信息添加到原型中。
       原型方式利用了對象的prototype 屬性,可以把它看成創建新對象所依賴的原型。這里,首先用空構造函數來設置函數名。然后所有的屬性和方法都被直接賦予prototype屬性。我重寫了前面的例子,代碼如下:

function Car() { }; //將所有的屬性的方法都賦予prototype屬性 Car.prototype.color = "blue"; Car.prototype.doors = 4; Car.prototype.mpg = 25; Car.prototype.showColor = function() {   return this.color; }; var Car1 = new Car(); var Car2 = new Car(); document.write(Car1.showColor()+"<br/>");//輸出:blue document.write(Car2.showColor());//輸出:blue 

      在這段代碼中,首先定義構造函數Car(),其中無任何代碼。接下來的幾行代碼,通過給Car的 prototype 屬性添加屬性去定義Car對象的屬性。調用new Car()時,原型的所有屬性都被立即賦予要創建的對象,意味著所有Car實例存放的都是指向 showColor() 函數的指針。從語義上講,所有屬性看起來都屬于一個對象,因此解決了前面的工廠方式和構造函數方式存在的問題。
       此外,使用這種方式,還能用 instanceof 運算符檢查給定變量指向的對象的類型:

復制代碼代碼如下:
<span style="font-size:18px;">document.write(Car1 instanceof Car);    //輸出:true</span> 

      原型方式看起來是個不錯的解決方案。遺憾的是,它并不盡如人意。首先,這個構造函數沒有參數。使用原型方式,不能通過給構造函數傳遞參數來初始化屬性的值,因為Car1和Car2的color屬性都等于 "blue",doors屬性都等于4,mpg屬性都等于25。這意味著必須在對象創建后才能改變屬性的默認值,這點很令人討厭,但還沒完。真正的問題出現在屬性指向的是對象,而不是函數時。函數共享不會造成問題,但對象卻很少被多個實例共享。請思考下面的例子:

 

function Car() { };//定義一個空構造函數,且不能傳遞參數 Car.prototype.color = "blue"; Car.prototype.doors = 4; Car.prototype.mpg = 25; Car.prototype.drivers = new Array("Mike","John"); Car.prototype.showColor = function() {   return this.color; }; var Car1 = new Car(); var Car2 = new Car(); Car1.drivers.push("Bill"); document.write(Car1.drivers+"<br/>");//輸出:Mike,John,Bill document.write(Car2.drivers);//輸出 :Mike,John,Bill 

       上面的代碼中,屬性drivers是指向Array對象的指針,該數組中包含兩個名"Mike"和 "John"。由于 drivers是引用值,Car的兩個實例都指向同一個數組。這意味著給Car1.drivers添加值 "Bill",在 Car2.drivers 中也能看到。輸出這兩個指針中的任何一個,結果都是顯示字符串 "Mike,John,Bill"。由于創建對象時有這么多問題,你一定會想,是否有種合理的創建對象的方法呢?答案是有,需要聯合使用構造函數和原型方式。
5、混合的構造函數/原型方式(推薦使用)
       混合使用構造函數方式和原型方式,就可像用其他程序設計語言一樣創建對象。這種概念非常簡單,即用構造函數定義對象的所有非函數屬性,用原型方式定義對象的函數屬性(方法)。結果是,所有函數都只創建一次,而每個對象都具有自己的對象屬性實例。我們重寫了前面的例子,代碼如下:

function Car(Color,Doors,Mpg) {  this.color = Color;  this.doors = Doors;  this.mpg = Mpg;  this.drivers = new Array("Mike","John"); }; Car.prototype.showColor = function() {    return this.color; }; var Car1 = new Car("red",4,23); var Car2 = new Car("blue",3,25); Car1.drivers.push("Bill"); document.write(Car1.drivers+"<br/>");//輸出:Mike,John,Bill documnet.write(Car2.drivers);//輸出:Mike,John 

       現在就更像創建一般對象了。所有的非函數屬性都在構造函數中創建,意味著又能夠用構造函數的參數賦予屬性默認值了。因為只創建showColor()函數的一個實例,所以沒有內存浪費。此外,給Car1的drivers數組添加 "Bill" 值,不會影響到Car2的數組,所以輸出這些數組的值時,Car1.drivers 顯示的是 "Mike,John,Bill",而 Car2.drivers 顯示的是 "Mike,John"。因為使用了原型方式,所以仍然能利用 instanceof運算符來判斷對象的類型。
       這種方式是ECMAScript采用的主要方式,它具有其他方式的特性,卻沒有他們的副作用。不過,有些開發者仍覺得這種方法不夠完美。
6、動態原型方式
      對于習慣使用其他語言的開發者來說,使用混合的構造函數/原型方式感覺不那么和諧。畢竟,定義類時,大多數面向對象語言都對屬性和方法進行了視覺上的封裝。請考慮下面的 Java 類:

class Car {  public String color = "blue";  public int doors = 4;  public int mpg = 25;  public Car(String color, int doors, int mpg) {   this.color = color;   this.doors = doors;   this.mpg = mpg;  }  public void showColor() {   System.out.println(color);  } } 

        Java很好地打包了Car類的所有屬性和方法,因此看見這段代碼就知道它要實現什么功能,它定義了一個對象的信息。批評混合的構造函數/原型方式的人認為,在構造函數內部找屬性,在其外部找方法的做法不合邏輯。因此,他們設計了動態原型方法,以提供更友好的編碼風格。
       動態原型方法的基本想法與混合的構造函數/原型方式相同,即在構造函數內定義非函數屬性,而函數屬性則利用原型屬性定義。唯一的區別是賦予對象方法的位置。下面是用動態原型方法重寫的Car:

function Car(Color,Doors,Mpg) {  this.color = Color;  this.doors = Doors;  this.mpg = Mpg;  this.drivers = new Array("Mike","John");  //如果Car對象中的_initialized為undefined,表明還沒有為Car的原型添加方法  if (typeof Car._initialized == "undefined") {    Car.prototype.showColor = function() {     return this.color;    };    Car._initialized = true; //設置為true,不必再為prototype添加方法  } } var Car1 = new Car("red",4,23);//生成一個Car對象 var Car2 = new Car("blue",3,25); Car1.drivers.push("Bill");//向Car1對象實例的drivers屬性添加一個元素 document.write(Car1.drivers+"<br/>");//輸出:Mike,John,Bill document.write(Car2.drivers);//輸出:Mike,John 

       直到檢查typeof Car._initialize是否等于"undefined"之前,這個構造函數都未發生變化。這行代碼是動態原型方法中最重要的部分。如果這個值未定義,構造函數將用原型方式繼續定義對象的方法,然后把 Car._initialized設置為true。如果這個值定義了(它的值為 true時,typeof 的值為Boolean),那么就不再創建該方法。簡而言之,該方法使用標志(_initialized)來判斷是否已給原型賦予了任何方法。該方法只創建并賦值一次,傳統的 OOP開發者會高興地發現,這段代碼看起來更像其他語言中的類定義了。
       我們應該采用哪種方式呢?
       如前所述,目前使用最廣泛的是混合的構造函數/原型方式。此外,動態原型方式也很流行,在功能上與構造函數/原型方式等價??梢圆捎眠@兩種方式中的任何一種。不過不要單獨使用經典的構造函數或原型方式,因為這樣會給代碼引入問題??傊甁S是基于面向對象的一門客戶端腳本語言,我們在學習它的面向對象技術的時候要的留意JS與其他嚴謹性高的程序語言的不同。也要正確使用JS創建對象的合理的方式,推薦使用構造函數與原型方式的混合方式創建對象實例。這樣可以避免許多不必要的麻煩。

以上就是JavaScript基于面向對象之創建對象的全部內容,希望對大家的學習有所幫助。



注:相關教程知識閱讀請移步到JavaScript/Ajax教程頻道。
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表

圖片精選

亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
狠狠躁夜夜躁人人爽超碰91| 国产精品男人爽免费视频1| 成人写真视频福利网| 国产情人节一区| 九九九热精品免费视频观看网站| 最近2019免费中文字幕视频三| 久久精品91久久香蕉加勒比| 欧美在线视频导航| 久久精品国产综合| 国产欧美韩国高清| 日韩经典中文字幕| 国产成人avxxxxx在线看| 亚洲三级黄色在线观看| 亚洲精品国产成人| 欧美刺激性大交免费视频| 国产欧美欧洲在线观看| 久久国产精品久久久久久久久久| 欧美精品一二区| 午夜精品蜜臀一区二区三区免费| 日本不卡免费高清视频| 国产精品流白浆视频| 成人淫片在线看| 久久人91精品久久久久久不卡| 国产精品999| 色99之美女主播在线视频| 欧美日韩在线第一页| 日韩av电影中文字幕| 欧美成人免费一级人片100| 亚洲一区二区三区四区在线播放| 亚洲一区二区三区毛片| 亚洲欧美日韩在线高清直播| 国产精品久久综合av爱欲tv| 中文精品99久久国产香蕉| 欧美性生活大片免费观看网址| 国产精品白嫩美女在线观看| 午夜美女久久久久爽久久| 日本一本a高清免费不卡| 国产精品高清在线观看| 欧美男插女视频| 国产在线视频不卡| 欧美精品午夜视频| 97在线精品国自产拍中文| 国外色69视频在线观看| 中文字幕亚洲综合久久| 久久精品国产亚洲精品| 91精品国产一区| 欧美大尺度在线观看| 欧美日韩美女视频| 91色视频在线观看| 欧美日韩综合视频| 欧美精品一本久久男人的天堂| 深夜福利一区二区| 日韩大陆欧美高清视频区| 精品国产欧美一区二区五十路| 亚洲人精品午夜在线观看| 日韩电影中文字幕av| 亚洲男人第一网站| 亚洲v日韩v综合v精品v| 欧美一区二区三区免费观看| 久久五月天综合| 亚洲欧美日韩爽爽影院| 日韩精品极品视频免费观看| 日韩国产一区三区| 2019国产精品自在线拍国产不卡| 久久久精品一区二区| 91网在线免费观看| 国产亚洲欧美日韩精品| 色偷偷9999www| 成人国产精品一区| 国内成人精品视频| 国产aⅴ夜夜欢一区二区三区| 欧美www视频在线观看| 欧美—级a级欧美特级ar全黄| 国产精品av免费在线观看| 国产精品www网站| 久久精品一本久久99精品| 国产精品女主播| 成人免费在线视频网站| 亚洲精品久久久久| 精品一区二区三区三区| 懂色av一区二区三区| 97av视频在线| 国产精品久久99久久| 国产美女搞久久| 精品久久久久久久久久国产| 国产精品第3页| 在线视频亚洲欧美| 欧美日韩亚洲网| 91精品久久久久久久久中文字幕| 亚洲成人网在线观看| 日韩精品在线免费观看| 国产一区二区三区在线观看视频| 欧美精品一区三区| 亚洲一区二区久久久久久| 中文字幕久热精品视频在线| 亚洲第一av在线| 法国裸体一区二区| 亚洲999一在线观看www| 亚洲精品一区二区久| 国产第一区电影| 欧美日本啪啪无遮挡网站| 中文字幕国产精品久久| 久久精品国产亚洲7777| 久久久久久有精品国产| 日本a级片电影一区二区| 国产精品视频免费观看www| 在线播放国产一区中文字幕剧情欧美| 国产一区二区三区视频| 日韩一区二区av| 国产在线999| 精品国产成人在线| 尤物yw午夜国产精品视频| 日日狠狠久久偷偷四色综合免费| 国产精品中文在线| 91国产视频在线播放| 欧美日韩在线观看视频| 美女啪啪无遮挡免费久久网站| 中文字幕9999| 亚洲国产精品系列| 亚洲高清色综合| 欧美孕妇孕交黑巨大网站| 欧美亚洲在线播放| 日日骚av一区| 日本精品va在线观看| 欧美激情精品久久久久久免费印度| 亚洲最大福利网站| 亚洲国产97在线精品一区| 日韩高清免费在线| 狠狠综合久久av一区二区小说| 久久久97精品| 91国产高清在线| 国产欧美一区二区三区四区| 国产97在线播放| 美乳少妇欧美精品| 97色伦亚洲国产| 亚洲国产一区二区三区四区| 欧美日韩免费网站| 国产精品久久91| 久久久久久久久久久人体| 欧美日韩在线免费观看| 91免费看片在线| 久久免费观看视频| 国产精品一二区| 午夜美女久久久久爽久久| 亚洲成av人影院在线观看| 亚洲欧美日韩一区二区三区在线| 久久成人av网站| 国产精品99免视看9| 久久国产精品影片| 国产亚洲欧美aaaa| 高潮白浆女日韩av免费看| 久久久久久这里只有精品| 久久综合免费视频| 亚洲毛片在线看| 亚洲iv一区二区三区| 高清欧美一区二区三区| 亚洲精品自拍视频| 国产精品99久久久久久白浆小说| 亚洲精品电影在线观看| 国产精品草莓在线免费观看| 国产午夜精品久久久| 亚洲欧洲偷拍精品| 午夜欧美不卡精品aaaaa| 欧洲永久精品大片ww免费漫画|