摘要:一類是以國內(nèi)的等類庫為代表的大教堂模式。在大教堂模式下,所有組件都是顆?;K化的,各組件之間層層分級環(huán)環(huán)相扣。在集市模式下,所有組件彼此獨立職責單一,各組件通過組合松耦合在一起,協(xié)同完成開發(fā)兼容性持續(xù)更新中。。。
前端模塊化開發(fā)的價值 解決命名沖突
我們做項目是常常會做一些通用功能的封裝,封裝成一個個的函數(shù),然后保存在一個名叫util.js的文件中.這種情況就很有可能在另一個開發(fā)人員開發(fā)時發(fā)生命名沖突.
解決繁瑣的文件依賴基于util.js,我們開始開發(fā)UI層通用組件dialog.js,那么我們現(xiàn)在的引用情況應(yīng)該這樣:
假如有更多的依賴關(guān)系引用起來就非常的繁瑣.
使用Sea.js來解決seajs是一個模塊管理框架,使用seajs需要遵守CMD(Common Module Definition)模塊定義規(guī)范.一個文件就是一個模塊.
通過define函數(shù)進行模塊定義.util.js文件的代碼如下:
define(function(require,exports){ exports.each = function(){ //實現(xiàn)代碼 }; esxports.log = function(str){ //實現(xiàn)代碼 } });
這里的exports向外提供了each和log方法,當這個模塊被引用時,可以調(diào)用這兩個方法.
通過require函數(shù)進行模塊調(diào)用.dialog.js文件的代碼如下:
define(function(require,exports){ var util = require("./util.js"); exports.init = function(){ util.each(); util.log(); } });
這里通過require("./util.js")來調(diào)用到util模塊.
Sea.js 帶來的好處通過exports暴露接口.這意味著不需要命名空間,也不需要全局變量,解決了命名沖突的問題.
通過require引入依賴.這是一種很好的關(guān)注分離,解決了繁瑣的文件依賴.
模塊的版本管理.通過別名等配置,配合構(gòu)建工具,可以比較輕松的實現(xiàn)模塊的版本管理.
提升可維護性. 模塊化可以讓每個文件的職責單一,非常利于代碼維護.seajs提供nocahce debug等插件,擁有在線調(diào)試等功能,能比較明顯的提升效率.
前端性惡能優(yōu)化.seajs通過異步加載模塊對頁面性能非常有益.seajs提供了combo flush插件,配合服務(wù)端,可以很好對頁面性能進行調(diào)優(yōu).
跨環(huán)境共享模塊.CMD模塊定義規(guī)范與NOdejs的模塊規(guī)范非常相近.通過seajs的Nodejs版本,可以很方便實現(xiàn)模塊的跨服務(wù)器和瀏覽器共享.
前端的模塊化構(gòu)建可分為兩大類。一類是以 Dojo、YUI3、國內(nèi)的 KISSY 等類庫為代表的大教堂模式。在大教堂模式下,所有組件都是顆?;⒛K化的,各組件之間層層分級、環(huán)環(huán)相扣。另一類是以 jQuery、RequireJS、國內(nèi)的 Sea.js、OzJS 等類庫為基礎(chǔ)的集市模式。在集市模式下,所有組件彼此獨立、職責單一,各組件通過組合松耦合在一起,協(xié)同完成開發(fā).
seajs兼容性Chorme 3+
Firfox 2+
Safari 3.2+
Opera 10+
IE 5.5+
持續(xù)更新中。。。文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請注明本文地址:http://systransis.cn/yun/78672.html
摘要:前端模塊化開發(fā)的價值惱人的命名沖突煩瑣的文件依賴使用來解決除了解決命名沖突和依賴管理,使用進行模塊化開發(fā)還可以帶來很多好處模塊的版本管理。模塊化可以讓每個文件的職責單一,非常有利于代碼的維護。模塊定義規(guī)范與的模塊規(guī)范非常相近。 前端模塊化開發(fā)的價值1、惱人的命名沖突2、煩瑣的文件依賴使用 Sea.js 來解決除了解決命名沖突和依賴管理,使用 Sea.js 進行模塊化開發(fā)還可以帶來很多好...
摘要:應(yīng)用日益復雜,模塊化已經(jīng)成為一個迫切需求。異步模塊加載機制。引用的資源列表太長,懶得回調(diào)函數(shù)中寫一一對應(yīng)的相關(guān)參數(shù)假定這里引用的資源有數(shù)十個,回調(diào)函數(shù)的參數(shù)必定非常多這就是傳說中的 簡述 緣起 模塊通常是指編程語言所提供的代碼組織機制,利用此機制可將程序拆解為獨立且通用的代碼單元。 模塊化主要是解決代碼分割、作用域隔離、模塊之間的依賴管理以及發(fā)布到生產(chǎn)環(huán)境時的自動化打包與處理等多個方面...
摘要:來源于阿賢博客模塊化今天給大家寫一篇關(guān)于前端模塊化開發(fā)知識點。前端模塊化開發(fā)那點歷史模塊化是指在解決某個復雜混雜問題時,依照一種分類的思維把問題進行系統(tǒng)性的分解以之處理。 來源于:阿賢博客 javascript模塊化 今天給大家寫一篇關(guān)于前端模塊化開發(fā)知識點。 前端模塊化開發(fā)那點歷史 模塊化: 是指在解決某個復雜、混雜問題時,依照一種分類的思維把問題進行系統(tǒng)性的分解以之處理。模塊...
摘要:所有依賴這個模塊的語句,都定義在一個回調(diào)函數(shù)中,等到所有依賴加載完成之后前置依賴,這個回調(diào)函數(shù)才會運行。如果將前面的代碼改寫成形式,就是下面這樣定義了一個文件,該文件依賴模塊,當模塊加載完畢之后執(zhí)行回調(diào)函數(shù),這里并沒有暴露任何變量。 模塊化是我們?nèi)粘i_發(fā)都要用到的基本技能,使用簡單且方便,但是很少人能說出來但是的原因及發(fā)展過程?,F(xiàn)在通過對比不同時期的js的發(fā)展,將JavaScript模...
閱讀 2435·2021-09-01 10:41
閱讀 1451·2019-08-30 14:12
閱讀 520·2019-08-29 12:32
閱讀 2868·2019-08-29 12:25
閱讀 2943·2019-08-28 18:30
閱讀 1713·2019-08-26 11:47
閱讀 989·2019-08-26 10:35
閱讀 2597·2019-08-23 18:06