网页越来越像桌面程序,需要一个团队分工协作、进度管理、单元测试等等......开发者不得不使用软件工程的方法,管理网页的业务逻辑。

Javascript模块化编程,已经成为一个迫切的需求。理想情">
首頁 web前端 js教程 Javascript模組化程式設計(一)模組的寫法最佳實務_基礎知識

Javascript模組化程式設計(一)模組的寫法最佳實務_基礎知識

May 16, 2016 pm 05:43 PM
模組化程式設計

隨著網站逐漸變成"網路應用程式",嵌入網頁的Javascript程式碼越來越龐大,也越來越複雜。
Javascript模組化程式設計(一)模組的寫法最佳實務_基礎知識 
網頁越來越像桌面程序,需要一個團隊分工協作、進度管理、單元測試等等......開發者不得不使用軟體工程的方法,管理網頁的業務邏輯。

Javascript模組化編程,已經成為一個迫切的需求。理想情況下,開發者只需要實作核心的業務邏輯,其他都可以載入別人已經寫好的模組。

但是,Javascript不是一種模組化程式語言,它不支援"類"(class),更遑論"模組"(module)了。 (正在製定中的ECMAScript標準第六版,將正式支援"類"和"模組",但還需要很長時間才能投入實用。)

Javascript社群做了很多努力,在現有的運作環境中,實現"模組"的效果。本文總結了目前"Javascript模組化程式設計"的最佳實踐,說明如何投入實用。雖然這不是初級教程,但只要稍稍了解Javascript的基本語法,就能看懂。
Javascript模組化程式設計(一)模組的寫法最佳實務_基礎知識 
一、原始寫法
模組就是實現特定功能的一組方法。
只要把不同的函數(以及記錄狀態的變數)簡單地放在一起,就算是一個模組。

複製程式碼 程式碼如下:

 〔/ 〔 /){   }
  function m2(){
    //...
  }

  }


這種做法的缺點很明顯:"污染"了全域變量,無法保證不與其他模組發生變量名衝突,而且模組成員之間看不出直接關係。
二、對象寫法
為了解決上面的缺點,可以把模組寫成一個對象,所有的模組成員都放到這個對象裡面。 複製程式碼
程式碼如下:


var module1 = new Object(>

var module1 = new Object({H. 0,
    m1 : function (){
      //...
        //...
    }
  }) ;


上面的函數m1()和m2(),都封裝在module1物件裡。使用的時候,就是呼叫這個物件的屬性。 程式碼如下:


 〜> 〜>1.m1();
但是,這樣的寫法會暴露所有模組成員,內部狀態可以被外部改寫。例如,外部程式碼可以直接改變內部計數器的值。

複製程式碼 程式碼如下:
  module1._

三、立即執行函數寫法

使用"立即執行函數"(Immediately-Invoked Function Expression,IIFE),可以達到不暴露私有成員的目的。

複製程式碼 程式碼如下: var module1 = (function(>
var module1 = (function()()> _count = 0;
    var m1 = function(){
      //...
      //...
    };    //...
    };
    return {
      m1 : m1,
      〕 🎜>

使用上面的寫法,外部程式碼無法讀取內部的_count變數。



複製程式碼

程式碼如下:   console.info(module1._count);
module1就是Javascript模組的基本寫法。下面,再對這種寫法進行加工。
四、放大模式
如果一個模組很大,必須分成幾個部分,或者一個模組需要繼承另一個模組,這時就有必要採用"放大模式"(augmentation) 。
複製程式碼 程式碼如下:

var module1 = (function (>

var module1 = (function (>
      //...
    };
   『為module1模組新增了一個新方法m3(),然後傳回新的module1模組。

五、寬放大模式(Loose augmentation)
在瀏覽器環境中,模組的各個部分通常都是從網路上取得的,有時無法知道哪個部分會先載入。如果採用上一節的寫法,第一個執行的部分有可能載入一個不存在空對象,這時就要採用"寬放大模式"。

複製程式碼 程式碼如下:
var module1 = ( function (>

var module1 = ( function (>
    return mod;
  })(window.module1 || {});

與"放大模式"相比,"寬放大模式"就是"立即執行函數"的參數可以是空物件。
六、輸入全域變數
獨立性是模組的重要特點,模組內部最好不與程式的其他部分直接互動。
為了在模組內部呼叫全域變量,必須明確地將其他變數輸入模組。
複製程式碼 程式碼如下:

var module1 = (function (>

var module1 = (function ($, YAHOO) {     //...
  })(jQuery, YAHOO);


上面的module1模組需要使用jQuery庫和YUI庫,這兩個庫(其實就是兩個庫模組)當作參數輸入module1。這樣做除了保證模組的獨立性,也使得模組之間的依賴關係變得明顯。

這個系列的第二部分,將討論如何在瀏覽器環境組織不同的模組、管理模組之間的依賴性。
(完)
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn

熱AI工具

Undresser.AI Undress

Undresser.AI Undress

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

AI Clothes Remover

AI Clothes Remover

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

Undress AI Tool

Undress AI Tool

免費脫衣圖片

Clothoff.io

Clothoff.io

AI脫衣器

AI Hentai Generator

AI Hentai Generator

免費產生 AI 無盡。

熱門文章

R.E.P.O.能量晶體解釋及其做什麼(黃色晶體)
2 週前 By 尊渡假赌尊渡假赌尊渡假赌
倉庫:如何復興隊友
4 週前 By 尊渡假赌尊渡假赌尊渡假赌
Hello Kitty Island冒險:如何獲得巨型種子
3 週前 By 尊渡假赌尊渡假赌尊渡假赌

熱工具

記事本++7.3.1

記事本++7.3.1

好用且免費的程式碼編輯器

SublimeText3漢化版

SublimeText3漢化版

中文版,非常好用

禪工作室 13.0.1

禪工作室 13.0.1

強大的PHP整合開發環境

Dreamweaver CS6

Dreamweaver CS6

視覺化網頁開發工具

SublimeText3 Mac版

SublimeText3 Mac版

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

在JavaScript中替換字符串字符 在JavaScript中替換字符串字符 Mar 11, 2025 am 12:07 AM

在JavaScript中替換字符串字符

jQuery檢查日期是否有效 jQuery檢查日期是否有效 Mar 01, 2025 am 08:51 AM

jQuery檢查日期是否有效

jQuery獲取元素填充/保證金 jQuery獲取元素填充/保證金 Mar 01, 2025 am 08:53 AM

jQuery獲取元素填充/保證金

10個jQuery手風琴選項卡 10個jQuery手風琴選項卡 Mar 01, 2025 am 01:34 AM

10個jQuery手風琴選項卡

10值得檢查jQuery插件 10值得檢查jQuery插件 Mar 01, 2025 am 01:29 AM

10值得檢查jQuery插件

HTTP與節點和HTTP-Console調試 HTTP與節點和HTTP-Console調試 Mar 01, 2025 am 01:37 AM

HTTP與節點和HTTP-Console調試

jQuery添加捲軸到Div jQuery添加捲軸到Div Mar 01, 2025 am 01:30 AM

jQuery添加捲軸到Div

自定義Google搜索API設置教程 自定義Google搜索API設置教程 Mar 04, 2025 am 01:06 AM

自定義Google搜索API設置教程

See all articles