JavaScript自訂屬性和方法的物件模型程式碼詳解
在JavaScript中,建立一個具有自訂屬性和方法的物件有很多種模式
1、直接建立模式。這是最簡單也是最直接的模式,首先建立一個引用類型的對象,然後為其新增自訂屬性和方法。範例程式碼如下:
var person = new Object(); person.name = "Sam"; person.age = 16; person.speak = function(){ alert(this.name + "is " + this.age + "years old"); } person.speak();
可以看到,上面建立了一個Object類型的對象,然後為其新增了name和age屬性以及一個speak方法。直接建立模式雖然簡單,但其缺點是顯而易見的:當我們需要建立許多相同的物件時,每次都要重複編寫程式碼。為了解決這個問題,我們可以將創建物件的過程進行封裝,於是便有了下面的工廠模式。
2、工廠模式。工廠模式是程式設計中常用的設計模式,它主要是將建立物件的過程進行了封裝,範例程式碼如下:
function createPerson(name, age){ var person = new Object(); person.name = name; person.age = age; person.speak = function(){ alert(this.name + "is " + this.age + "years old"); } return person; } var person1 = createPerson("Sam", 16); var person2 = createPerson("Jack", 18);
使用工廠模式後,建立相同類型的物件變得簡單了。但工廠模式沒有解決物件辨識的問題,也就是我們無法確定創建的物件的具體類型。有過物件導向程式設計經驗的開發人員都知道,物件的創建應當基於類,有了具體的自訂類,再來創建該類別的物件。幸好,在JavaScript中,我們可以透過建構函數模式來模擬一個類別。
3、建構函式模式。構造函數和普通函數沒有任何區別。任何普通函數都可以當作建構函數,只要使用new運算元即可;任何建構函數也都可以當作普通函數來呼叫。只不過在JavaScript中,有一個約定,就是用來作為建構函數的函數名稱需要一個首字母大寫。範例程式碼如下:
function Person(name, age){ this.name = name; this.age = age; this.speak = function(){ alert(this.name + "is " + this.age + "years old"); } } var person1 = new Person("Sam", 16); var person2 = new Person("Jack", 18);
可以看到,在建構函式內部,我們使用了this來新增屬性和方法,那麼,這個this是指什麼呢?當我們建立了一個Person的物件時,this也就是指這個被建立的物件。現在,我們可以辨識出物件person1和person2的具體類型了。使用alert(person1 instanceOf Person)後可以發現,輸出的值為true。但建構函式模式也有自己的缺點,就是建構函式內宣告的方法在每次建立新物件時都會重新建立(在JavaScript中,函數也是物件)。也就是說,建構函式內的方法是與物件綁定的,而不是與類別綁定的。下面程式碼的輸出可以驗證我們的推斷。
alert(person1.speak == person2.speak); // false 解決這個缺點的一個比較簡單的方法就是將函數的宣告放到建構子的外面,即:
function Person(name, age){ this.name = name; this.age = age; this.speak = speak; } function speak(){ alert(this.name + "is " + this.age + "years old"); } var person1 = new Person("Sam", 16); var person2 = new Person("Jack", 18); alert(person1.speak == person2.speak); // true
問題解決了,但這種方法又帶來了新的問題。首先,函數speak是在全域作用域中宣告的,但它卻只能被用於Person建構函數,放在全域作用域中有被誤用的風險;其次,如果一個自訂型別有很多的方法,則需要宣告很多的全域函數,這不僅會導致全域作用域的污染,也不利於程式碼的封裝。那麼,有沒有辦法能讓自訂類型的方法成為與類別綁定的,又不污染全域作用域呢?答案是使用原型模式。
4、原型模式。在我們宣告一個新的函數後,該函數(在JavaScript中,函數也是物件)就會擁有一個prototype的屬性。 prototype是一個對象,表示會被該函數所建立的所有物件擁有的公共屬性和方法。範例程式碼如下:
function Person(){} Person.prototype.name="Sam"; Person.prototype.age=16; Person.prototype.speak = function(){ alert(this.name + "is " + this.age + "years old"); } var person1 = new Person(); person1.speak(); var person2 = new Person(); alert(person1.speak == person2.speak); // true
可以看到,雖然建構函式內沒有宣告speak方法,但我們建立的物件person1還是能呼叫speak方法,這是因為JavaScript有一個搜尋規則,先搜尋實例屬性和方法,找到則回傳;如果沒找到,則再到prototype中去搜尋。原型模式使得方法是與類別相關的,並且沒有污染全域作用域,但其也有自身的缺點:一是所有屬性也都與類別相關,這意味著所有物件共享一份屬性,這顯然是不合理的;二是沒有辦法向構造函數傳入初始化資料了。解決的方法很簡單,就是混合使用建構函式模式和原型模式。
5、組合模式。範例程式碼如下:
function Person(name, age){ this.name = name; this.age = age; } Person.prototype.speak = function(){ alert(this.name + "is " + this.age + "years old"); } var person1 = new Person(); person1.speak(); var person2 = new Person(); alert(person1.speak == person2.speak); // true
不難發現,組合模式實現了我們的所有需求,這也是目前應用得比較廣泛的一種模式。有物件導向程式設計經驗的開發人員可能會覺得將prototype的聲明放在建構函式外面有點彆扭,那麼能否將其放到建構函式裡去呢?答案是肯定的,使用動態組合模式即可。
6、動態組合模式。其原理就是先判斷原型中的某個屬性或方法是不是已經聲明過,如果沒有聲明,則聲明整個原型;否則,什麼也不用做。範例程式碼如下:
function Person(name, age){ this.name = name; this.age = age; if (Person.prototype.speak == "undefined"){ Person.prototype.speak = function(){ alert(this.name + "is " + this.age + "years old"); } } }
以上是JavaScript自訂屬性和方法的物件模型程式碼詳解的詳細內容。更多資訊請關注PHP中文網其他相關文章!

熱AI工具

Undresser.AI Undress
人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover
用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

AI Hentai Generator
免費產生 AI 無盡。

熱門文章

熱工具

記事本++7.3.1
好用且免費的程式碼編輯器

SublimeText3漢化版
中文版,非常好用

禪工作室 13.0.1
強大的PHP整合開發環境

Dreamweaver CS6
視覺化網頁開發工具

SublimeText3 Mac版
神級程式碼編輯軟體(SublimeText3)

熱門話題

Netflix上的頭像是你串流媒體身分的視覺化代表。使用者可以超越預設的頭像來展現自己的個性。繼續閱讀這篇文章,了解如何在Netflix應用程式中設定自訂個人資料圖片。如何在Netflix中快速設定自訂頭像在Netflix中,沒有內建功能來設定個人資料圖片。不過,您可以透過在瀏覽器上安裝Netflix擴充功能來實現此目的。首先,在瀏覽器上安裝Netflix擴充功能的自訂個人資料圖片。你可以在Chrome商店買到它。安裝擴充功能後,在瀏覽器上開啟Netflix並登入您的帳戶。導航至右上角的個人資料,然後點擊

人臉偵測辨識技術已經是一個比較成熟且應用廣泛的技術。而目前最廣泛的網路應用語言非JS莫屬,在Web前端實現人臉偵測辨識相比後端的人臉辨識有優勢也有弱勢。優點包括減少網路互動、即時識別,大大縮短了使用者等待時間,提高了使用者體驗;弱勢是:受到模型大小限制,其中準確率也有限。如何在web端使用js實現人臉偵測呢?為了實現Web端人臉識別,需要熟悉相關的程式語言和技術,如JavaScript、HTML、CSS、WebRTC等。同時也需要掌握相關的電腦視覺和人工智慧技術。值得注意的是,由於Web端的計

如何在Eclipse中自訂快捷鍵設定?身為開發人員,在使用Eclipse進行編碼時,熟練快捷鍵是提高效率的關鍵之一。 Eclipse作為一個強大的整合開發環境,不僅提供了許多預設的快捷鍵,還允許使用者根據自己的偏好進行個人化的客製化。本文將介紹如何在Eclipse中自訂快捷鍵設置,並給出具體的程式碼範例。打開Eclipse首先,打開Eclipse,並進入

1.下圖是edius預設的螢幕佈局,預設的EDIUS視窗佈局是橫向版式,因此在單一顯示器環境中,許多視窗是重疊在一起的,且預覽視窗為單一視窗模式。 2、您可以透過【檢視】選單列啟用【雙視窗模式】,使預覽視窗同時顯示播放視窗和錄製視窗。 3.您可以透過【檢視功能表列>視窗佈局>常規】來恢復預設螢幕佈局。另外您也可以自訂適合您的佈局方式,並儲存為常用螢幕佈局:將視窗拖曳成適合自己的佈局,然後點擊【檢視>視窗佈局>儲存目前佈局>新建】,在彈出的【儲存目前佈局】小視窗中輸入佈局名稱,按確定

在excel表格中,有時候可能需要插入座標軸,能夠更直觀地看到資料的變化趨勢。還有些小夥伴不清楚怎麼在表中插入座標軸,接下來小編就跟大家分享一下excel自訂座標軸刻度的方法吧。 座標軸插入方法: 1、在excel介面中,選取資料。 2、在插入介面中,點選插入長條圖或長條圖。 3、在展開的介面中,選擇形圖類型。 4、在表格右鍵介面中,點選選擇資料。 5、在展開的介面中,進行自訂即可。

隨著網路金融的快速發展,股票投資已經成為了越來越多人的選擇。而在股票交易中,蠟燭圖是常用的技術分析方法,它能夠顯示股票價格的變動趨勢,幫助投資人做出更精準的決策。本文將透過介紹PHP和JS的開發技巧,帶領讀者了解如何繪製股票蠟燭圖,並提供具體的程式碼範例。一、了解股票蠟燭圖在介紹如何繪製股票蠟燭圖之前,我們首先需要先了解什麼是蠟燭圖。蠟燭圖是由日本人

JavaScript教學:如何取得HTTP狀態碼,需要具體程式碼範例前言:在Web開發中,經常會涉及到與伺服器進行資料互動的場景。在與伺服器進行通訊時,我們經常需要取得傳回的HTTP狀態碼來判斷操作是否成功,並根據不同的狀態碼來進行對應的處理。本篇文章將教你如何使用JavaScript來取得HTTP狀態碼,並提供一些實用的程式碼範例。使用XMLHttpRequest

js和vue的關係:1、JS作為Web開發基石;2、Vue.js作為前端框架的崛起;3、JS與Vue的互補關係;4、JS與Vue的實踐應用。
