欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

seaJs的模塊定義和模塊加載淺析

 更新時(shí)間:2014年06月06日 11:13:49   作者:  
這篇文章主要介紹了seaJs的模塊定義和模塊加載淺析,以及模塊間的依賴關(guān)系等問題,需要的朋友可以參考下

SeaJS 是由玉伯開發(fā)的一個(gè)遵循 CommonJS 規(guī)范的模塊加載框架,可用來(lái)輕松愉悅地加載任意 JavaScript 模塊和css模塊樣式。SeaJS非常小巧,小巧在于壓縮和gzip后體積只有4K,而且接口和方法也非常少,SeaJS 就兩個(gè)核心:模塊定義和 模塊的加載及依賴關(guān)系。SeaJS非常強(qiáng)大,SeaJS可以加載任意 JavaScript 模塊和css模塊樣式,SeaJS會(huì)保證你在使用一個(gè)模塊時(shí),已經(jīng)將所依賴的其他模塊載入到腳本運(yùn)行環(huán)境中。玉伯的說法,SeaJS可以讓你享受寫代碼的樂趣,不用去管那些加載的問題。你是否厭倦了如此多的js和css引用,我數(shù)了一下我們公司網(wǎng)站的個(gè)人主頁(yè)首頁(yè)上有39個(gè)css和js引用,帶來(lái)的影響可想而知:

1.不利于維護(hù),前端后端都一樣
2.http請(qǐng)求過多,當(dāng)然這個(gè)可以通過合并解決,但是如果沒有后端直接合并,人工成本非常大,就算后端合并,維護(hù)的時(shí)候,這么長(zhǎng)的一個(gè)字符串,眼睛肯定看花

用SeaJS就能非常好的解決這些問題。

模塊的定義define

定義一個(gè)模塊比較簡(jiǎn)單,例如定義一個(gè)sayHello模塊,建一個(gè)sayHello.js文檔:

復(fù)制代碼 代碼如下:

define(function(require,exports,module){
 exports.sayHello = function(eleID,text) {
  document.getElementById(eleID).innerHTML=text;
 };
});

這里先看一下exports參數(shù),exports參數(shù)是用來(lái)向外提供模塊的 API.也就是通過這個(gè)exports其他的模塊就能訪問sayHello方法。

模塊的加載use

例如我們頁(yè)面上有一個(gè)id為“out”的元素,要輸出“Hello SeaJS!”,
那么我們可以先引入sea.js
然后使用sayHello模塊:

復(fù)制代碼 代碼如下:

seajs.use("sayHello/sayHello",function(say){
 say.sayHello("out","Hello SeaJS!");
});

這里的use就是使用模塊的方法:

第一個(gè)參數(shù)就是模塊表示,他是相對(duì)于sea.js的相對(duì)路徑來(lái)表示,sayHello.js后面的“.js”后綴可以省略,當(dāng)然這個(gè)模塊標(biāo)識(shí)還有很多方法,具體查看官方說明:http://seajs.com/docs/zh-cn/module-identifier.html
第一個(gè)參數(shù)是一個(gè)callback函數(shù)。say.sayHello()就是調(diào)用sayHello模塊的exports.sayHello方法,當(dāng)然這callback函數(shù)中有個(gè)say參數(shù)。

模塊的依賴關(guān)系

模塊的依賴其實(shí)在模塊定義的時(shí)候就應(yīng)該存在了。比如說把上面的sayHello模塊改寫一下,假設(shè)我們已經(jīng)有了一個(gè)通用的DOM模塊,比如一些獲取元素,設(shè)置樣式等方法,例如這么一個(gè)DOM模塊,如下編寫DOM.js

復(fù)制代碼 代碼如下:

define(function(require, exports, module) {
    var DOM = {
        /**
* 通過元素的id屬性獲取DOM對(duì)象,參數(shù)為字符串,或多個(gè)字符串
* @id getById
* @method getById
* @param {String} id the id attribute
* @return {HTMLElement | Object} The HTMLElement with the id, or null if none found.
*/
        getById: function() {
            var els = [];
            for (var i = 0; i < arguments.length; i++) {
                var el = arguments[i];
                if (typeof el == "string") {
                    el = document.getElementById(el);
                }
                if (arguments.length == 1) {
                    return el;
                }
                els.push(el);
            }
            return els;
        },
        /**
* get 獲取對(duì)象,可以傳入對(duì)象或字符串,如果傳入字符串者以document.getElementById()的方式獲取對(duì)象
* @id get
* @param {String} el html element
* @return {Object} HTMLElement object.
*/
        get: function(el) {
            if (el & amp; amp; amp; & amp; amp; amp; (el.tagName || el.item)) {
                return el;
            }
            return this.getById(el);
        }
    };
    return DOM;
});

那么sayHello模塊可以這樣編寫,為了不影響原來(lái)的demo頁(yè)面,所以我定一個(gè)新的sayHelloA模塊,我們可以這樣編寫sayHelloA.js:
復(fù)制代碼 代碼如下:

define(function(require, exports, module) {
    var DOM = require("DOM/DOM");
    require("sayHelloA/sayHello.css");
    exports.sayHello = function(eleID, text) {
        DOM.get(eleID).innerHTML = text;
    };
});

require 函數(shù)就是用來(lái)建立模塊的依賴關(guān)系,比如上面sayHelloA模塊,就是依賴于DOM模塊,因?yàn)橛玫搅薉OM模塊的get方法。
注意這里的var DOM=require("DOM/DOM"),這句是將應(yīng)用進(jìn)來(lái)的DOM模塊賦值給DOM;require("sayHelloA/sayHello.css")是直接應(yīng)用sayHello.css css模塊或者說文件。這樣頁(yè)面上會(huì)引用這個(gè)css文件。

最近這幾天一直搗騰SeaJS,越搗騰越喜歡,感謝玉伯!感謝SeaJS!當(dāng)然你可能覺得這么簡(jiǎn)單的幾個(gè)實(shí)例沒必要這么做。確實(shí)如果js文件少的小項(xiàng)目感覺不錯(cuò)模塊化的優(yōu)勢(shì),但是,更多的在js文件多或著中型以上項(xiàng)目這個(gè)模塊化的優(yōu)勢(shì)就體現(xiàn)出來(lái)了。

相關(guān)文章

  • Seajs 簡(jiǎn)易文檔 提供簡(jiǎn)單、極致的模塊化開發(fā)體驗(yàn)

    Seajs 簡(jiǎn)易文檔 提供簡(jiǎn)單、極致的模塊化開發(fā)體驗(yàn)

    這篇文章主要介紹了Seajs 簡(jiǎn)易文檔 提供簡(jiǎn)單、極致的模塊化開發(fā)體驗(yàn),非官方文檔,整理來(lái)自己官方文檔的文字與實(shí)例,方便速查。需要的朋友可以參考下
    2016-04-04
  • SeaJS入門教程系列之完整示例(三)

    SeaJS入門教程系列之完整示例(三)

    這篇文章主要介紹了SeaJS入門教程系列之完整示例,演示了一個(gè)完整的SeaJS開發(fā)例子,需要的朋友可以參考下
    2014-03-03
  • Vue實(shí)現(xiàn)圖片懶加載的多種方法詳解

    Vue實(shí)現(xiàn)圖片懶加載的多種方法詳解

    圖片懶加載是前端開發(fā)中一項(xiàng)重要的性能優(yōu)化策略,它能夠明顯縮短頁(yè)面加載時(shí)間,提升用戶的瀏覽體驗(yàn),在本文中,我們將深入探討在Vue開發(fā)時(shí)候如何實(shí)現(xiàn)圖片懶加載,同時(shí)探討多種實(shí)現(xiàn)途徑,需要的朋友可以參考下
    2023-08-08
  • Seajs源碼詳解分析

    Seajs源碼詳解分析

    近幾年前端工程化越來(lái)越完善,打包工具也已經(jīng)是前端標(biāo)配了,像seajs這種老古董早已停止維護(hù),這是一篇細(xì)細(xì)品味Seajs源碼的文章,看完一定受益匪淺
    2019-04-04
  • seajs實(shí)現(xiàn)強(qiáng)制刷新本地緩存的方法分析

    seajs實(shí)現(xiàn)強(qiáng)制刷新本地緩存的方法分析

    這篇文章主要介紹了seajs實(shí)現(xiàn)強(qiáng)制刷新本地緩存的方法,結(jié)合實(shí)例形式簡(jiǎn)單分析了seajs強(qiáng)制刷新本地緩存的原理、實(shí)現(xiàn)方法及相關(guān)注意事項(xiàng),需要的朋友可以參考下
    2017-10-10
  • seajs模塊壓縮問題與解決方法實(shí)例分析

    seajs模塊壓縮問題與解決方法實(shí)例分析

    這篇文章主要介紹了seajs模塊壓縮問題與解決方法,結(jié)合實(shí)例形式分析了seajs模塊壓縮過程中出現(xiàn)的問題及相應(yīng)的解決方法,需要的朋友可以參考下
    2017-10-10
  • sea.js常用的api簡(jiǎn)易文檔

    sea.js常用的api簡(jiǎn)易文檔

    現(xiàn)在使用sea.js的公司越來(lái)越多, 比如阿里巴巴,淘寶網(wǎng),百姓網(wǎng),支付寶,有道云筆記等。模塊化的javascript開發(fā)帶來(lái)了可維護(hù)、可擴(kuò)展性,尤其在多人協(xié)作開發(fā)的時(shí)候不用再擔(dān)心文件依賴和函數(shù)命名沖突的問題,本文給大家分享了sea.js常用的api簡(jiǎn)易文檔,下面來(lái)一起看看吧
    2016-11-11
  • SeaJS入門教程系列之SeaJS介紹(一)

    SeaJS入門教程系列之SeaJS介紹(一)

    這篇文章主要介紹了SeaJS入門教程,講述了SeaJS的由來(lái),JavaScript傳統(tǒng)開發(fā)模式和模塊化開發(fā)的對(duì)比,需要的朋友可以參考下
    2014-03-03
  • LABjs、RequireJS、SeaJS的區(qū)別

    LABjs、RequireJS、SeaJS的區(qū)別

    這篇文章主要介紹了LABjs、RequireJS、SeaJS的區(qū)別、JS文件加載器、JS塊加載器等知識(shí),需要的朋友可以參考下
    2014-03-03
  • seajs中模塊的解析規(guī)則詳解和模塊使用總結(jié)

    seajs中模塊的解析規(guī)則詳解和模塊使用總結(jié)

    這篇文章主要介紹了seajs中模塊的解析規(guī)則詳解和模塊使用總結(jié),需要的朋友可以參考下
    2014-03-03

最新評(píng)論