隨著網站逐漸變成”互聯網應用程式”,嵌入網頁的Javascript程式碼越來越龐大,越來越複雜。
網頁越來越像桌面程序,需要一個團隊分工協作、進度管理、單元測試等等…開發者必須使用軟體工程的方法,管理網頁的業務邏輯。
JavaScript模組化編程,已經成為一個迫切的需求。理想情況下,開發者只需要實作核心的業務邏輯,其他都可以載入別人已經寫好的模組。
但是,Javascript不是一種模組化程式語言,它不支援」類別」(class),更遑論」模組」(module)了。 (正在製定中的ECMAScript標準第六版,將正式支援”類別”和“模組”,但還需要很長時間才能投入實用。)
Javascript社區做了很多努力,在現有的運行環境中,實現”模組”的效果。本文總結了目前"Javascript模組化程式設計"的最佳實踐,說明如何投入實用。雖然這不是初級教程,但只要稍稍了解Javascript的基本語法,就能看懂。
一、原始寫法
模組就是實作特定功能的一組方法。
只要把不同的函數(以及記錄狀態的變數)簡單地放在一起,就算是一個模組。
function m1(){ //... } function m2(){ //... }
上面的函數m1()和m2(),組成一個模組。使用的時候,直接呼叫就行了。
這種做法的缺點很明顯:」污染」了全域變量,無法保證不與其他模組發生變數名稱衝突,而且模組成員之間看不出直接關係。
二、物件寫法
為了解決上面的缺點,可以把模組寫成一個對象,所有的模組成員都放到這個物件裡面。
var module1 = new Object({ _count : 0, m1 : function (){ //... }, m2 : function (){ //... } });
上面的函數m1()和m2(),都封裝在module1物件裡。使用的時候,就是呼叫這個物件的屬性。
module1.m1();
但是,這樣的寫法會暴露所有模組成員,內部狀態可以被外部改寫。例如,外部程式碼可以直接改變內部計數器的值。
module1._count = 5;
三、立即執行函數寫法
使用」立即執行函數「(Immediately-Invoked Function Expression,IIFE),可以達到不暴露私有成員的目的。
var module1 = (function(){ var _count = 0; var m1 = function(){ //... }; var m2 = function(){ //... }; return { m1 : m1, m2 : m2 }; })();
使用上面的寫法,外部程式碼無法讀取內部的_count變數。
console.info(module1._count); //undefined
module1就是Javascript模組的基本寫法。下面,再對這種寫法進行加工。
四、放大模式
如果一個模組很大,必須分成幾個部分,或者一個模組需要繼承另一個模組,這時就有必要採用」放大模式」(augmentation) 。
var module1 = (function (mod){ mod.m3 = function () { //... }; return mod; })(module1);
上面的程式碼為module1模組新增了一個新方法m3(),然後傳回新的module1模組。
五、寬放大模式(Loose augmentation)
在瀏覽器環境中,模組的各個部分通常都是從網路上取得的,有時無法知道哪個部分會先載入。如果採用上一節的寫法,第一個執行的部分有可能載入一個不存在空對象,這時就要採用」寬放大模式」。
var module1 = ( function (mod){ //... return mod; })(window.module1 || {});
與」放大模式」相比,"寬放大模式"就是」立即執行函數」的參數可以是空物件。
六、輸入全域變數
獨立性是模組的重要特點,模組內部最好不與程式的其他部分直接互動。
為了在模組內部呼叫全域變量,必須明確地將其他變數輸入模組。
var module1 = (function ($, YAHOO) { //... })(jQuery, YAHOO);
上面的module1模組需要使用jQuery函式庫和YUI函式庫,就把這兩個函式庫(其實是兩個模組)當作參數輸入module1。這樣做除了保證模組的獨立性,也使得模組之間的依賴關係變得明顯。這方面更多的討論,請參見Ben Cherry的著名文章《JavaScript Module Pattern: In-Depth》。
這個系列的第二部分,將討論如何在瀏覽器環境組織不同的模組、管理模組之間的依賴性。
以上就是JavaScript 模組化程式設計(一):模組的寫法的內容,更多相關內容請關注PHP中文網(www.php.cn)!
#

JavaScript在現實世界中的應用包括服務器端編程、移動應用開發和物聯網控制:1.通過Node.js實現服務器端編程,適用於高並發請求處理。 2.通過ReactNative進行移動應用開發,支持跨平台部署。 3.通過Johnny-Five庫用於物聯網設備控制,適用於硬件交互。

我使用您的日常技術工具構建了功能性的多租戶SaaS應用程序(一個Edtech應用程序),您可以做同樣的事情。 首先,什麼是多租戶SaaS應用程序? 多租戶SaaS應用程序可讓您從唱歌中為多個客戶提供服務

本文展示了與許可證確保的後端的前端集成,並使用Next.js構建功能性Edtech SaaS應用程序。 前端獲取用戶權限以控制UI的可見性並確保API要求遵守角色庫

JavaScript是現代Web開發的核心語言,因其多樣性和靈活性而廣泛應用。 1)前端開發:通過DOM操作和現代框架(如React、Vue.js、Angular)構建動態網頁和單頁面應用。 2)服務器端開發:Node.js利用非阻塞I/O模型處理高並發和實時應用。 3)移動和桌面應用開發:通過ReactNative和Electron實現跨平台開發,提高開發效率。

JavaScript的最新趨勢包括TypeScript的崛起、現代框架和庫的流行以及WebAssembly的應用。未來前景涵蓋更強大的類型系統、服務器端JavaScript的發展、人工智能和機器學習的擴展以及物聯網和邊緣計算的潛力。

JavaScript是現代Web開發的基石,它的主要功能包括事件驅動編程、動態內容生成和異步編程。 1)事件驅動編程允許網頁根據用戶操作動態變化。 2)動態內容生成使得頁面內容可以根據條件調整。 3)異步編程確保用戶界面不被阻塞。 JavaScript廣泛應用於網頁交互、單頁面應用和服務器端開發,極大地提升了用戶體驗和跨平台開發的靈活性。

Python更适合数据科学和机器学习,JavaScript更适合前端和全栈开发。1.Python以简洁语法和丰富库生态著称,适用于数据分析和Web开发。2.JavaScript是前端开发核心,Node.js支持服务器端编程,适用于全栈开发。

JavaScript不需要安裝,因為它已內置於現代瀏覽器中。你只需文本編輯器和瀏覽器即可開始使用。 1)在瀏覽器環境中,通過標籤嵌入HTML文件中運行。 2)在Node.js環境中,下載並安裝Node.js後,通過命令行運行JavaScript文件。


熱AI工具

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

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

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

AI Hentai Generator
免費產生 AI 無盡。

熱門文章

熱工具

Atom編輯器mac版下載
最受歡迎的的開源編輯器

ZendStudio 13.5.1 Mac
強大的PHP整合開發環境

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

WebStorm Mac版
好用的JavaScript開發工具

Safe Exam Browser
Safe Exam Browser是一個安全的瀏覽器環境,安全地進行線上考試。該軟體將任何電腦變成一個安全的工作站。它控制對任何實用工具的訪問,並防止學生使用未經授權的資源。