使用一些Javascript 框架時,或許會看到類似的程式碼
var MyClass = new Class({
initialize: function(param, ...) {
this.param = param.param =>; },
func1: function( ...) {
...
}
});
var myObj = newClass(param);
var myObj = newClass(param); 🎜 >
這是一種典型的物件導向的類別機制應用,與原生的Javascript 類別機制相比,顯得更為清晰且自然。並且,在此基礎上,實作類別的繼承也較為方便。那麼,這是如何實現的呢?
眾所周知,在Javascript 中,將一個函數作為構造器,可以創建出一個對象,上面的程式碼可以簡單的寫成:
複製程式碼
}
var myObj = new MyClass(param);
myObj.func1();
蠻難的理解。不過如果要建立一套大型的Javascript 類別庫,可能就會比較混亂,從一堆程式碼中,要找出哪些是類,哪些是函數,哪些是類別方法,哪些是類別屬性,是一件痛苦的事。
當然,這裡並不是要比較它們的優劣,只是好奇 new Class 的實作方式而已。
在上面的程式碼中,使用new MyClass() 這樣的語句,意味著MyClass 必須是一個函數,同時也意味著new Class 需要傳回一個函數對象,從字面的意思可以看出,函數initialize是當做建構函式來使用的,所以,new Class 傳回的函式中,必須使用initialize 來對物件進行初始化。基於這樣的分析,可以得到以下程式碼:
複製程式碼
程式碼如下:
this 的轉換有些讓人頭暈,那麼有沒有更簡單的方法呢?請看下面的程式碼:
複製程式碼
程式碼如下:
argu)
var obj = argu['initialize'] || function() {};
for(var p in argu) {
,感覺直白了。
這就完成了一個簡單的類別機制的建構。透過這種機制,可以創建類別的建構函數、方法及屬性,但這些顯然都是公有的,那麼,如何實現私有變數及方法呢?
我們知道,Javascript 類別的私有變數可以透過閉包的機制來完成。但使用 new Class({...}) 的方式轉換後,顯然很難形成有效的閉包。如何繞過這個問題?
Javascript 提供了兩種方法:eval() 及函數物件的 toString() 方法,前者較為常見,而後者,可用於取得函數的具體程式碼。透過這兩個方法,可以簡單的模擬類別的私有變數:
程式碼如下:
function Class(argu) {
var _ = argu['private'] || {};
[ ) {}).toString());
for(var p in argu) {
if(p == 'initialize' || p == 'private') if (typeof argu[p] == 'function')
eval('obj.prototype[p] = ' argu[p].to()); }
return obj;
}
透過函數方法的程式碼使用這些方法的程式碼這樣就可以建構出一個有效的閉包範圍,進而實現私有機制。我們可以如下套用:
複製程式碼
initialize: function(name, height, weight) {
this.name = name;
_.height = height || _.height;
_.weight = weight || _.weight;
}, }
});
var my = new Person("Zh");
var my = new Person("Zh");
var my = new Person("Zh"); );
看起來不不錯,不過在實際應用中,其實並沒有太大的用途。主要是效率上,比起通常的實現方式,大概要多花四倍的時間。在大型類別庫的建置上,這是不可容忍的,而小型的應用中,實作下面的程式碼更為簡單直接:
}
}

JavaScript字符串替換方法詳解及常見問題解答 本文將探討兩種在JavaScript中替換字符串字符的方法:在JavaScript代碼內部替換和在網頁HTML內部替換。 在JavaScript代碼內部替換字符串 最直接的方法是使用replace()方法: str = str.replace("find","replace"); 該方法僅替換第一個匹配項。要替換所有匹配項,需使用正則表達式並添加全局標誌g: str = str.replace(/fi

本教程向您展示瞭如何將自定義的Google搜索API集成到您的博客或網站中,提供了比標準WordPress主題搜索功能更精緻的搜索體驗。 令人驚訝的是簡單!您將能夠將搜索限制為Y

本文系列在2017年中期進行了最新信息和新示例。 在此JSON示例中,我們將研究如何使用JSON格式將簡單值存儲在文件中。 使用鍵值對符號,我們可以存儲任何類型的

因此,在這裡,您準備好了解所有稱為Ajax的東西。但是,到底是什麼? AJAX一詞是指用於創建動態,交互式Web內容的一系列寬鬆的技術。 Ajax一詞,最初由Jesse J創造

利用輕鬆的網頁佈局:8 ESTISSEL插件jQuery大大簡化了網頁佈局。 本文重點介紹了簡化該過程的八個功能強大的JQuery插件,對於手動網站創建特別有用

核心要點 JavaScript 中的 this 通常指代“擁有”該方法的對象,但具體取決於函數的調用方式。 沒有當前對象時,this 指代全局對象。在 Web 瀏覽器中,它由 window 表示。 調用函數時,this 保持全局對象;但調用對象構造函數或其任何方法時,this 指代對象的實例。 可以使用 call()、apply() 和 bind() 等方法更改 this 的上下文。這些方法使用給定的 this 值和參數調用函數。 JavaScript 是一門優秀的編程語言。幾年前,這句話可

jQuery是一個很棒的JavaScript框架。但是,與任何圖書館一樣,有時有必要在引擎蓋下發現發生了什麼。也許是因為您正在追踪一個錯誤,或者只是對jQuery如何實現特定UI感到好奇

該帖子編寫了有用的作弊表,參考指南,快速食譜以及用於Android,BlackBerry和iPhone應用程序開發的代碼片段。 沒有開發人員應該沒有他們! 觸摸手勢參考指南(PDF)是Desig的寶貴資源


熱AI工具

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

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

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

AI Hentai Generator
免費產生 AI 無盡。

熱門文章

熱工具

WebStorm Mac版
好用的JavaScript開發工具

Dreamweaver CS6
視覺化網頁開發工具

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

DVWA
Damn Vulnerable Web App (DVWA) 是一個PHP/MySQL的Web應用程序,非常容易受到攻擊。它的主要目標是成為安全專業人員在合法環境中測試自己的技能和工具的輔助工具,幫助Web開發人員更好地理解保護網路應用程式的過程,並幫助教師/學生在課堂環境中教授/學習Web應用程式安全性。 DVWA的目標是透過簡單直接的介面練習一些最常見的Web漏洞,難度各不相同。請注意,該軟體中

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