亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 編程 > JavaScript > 正文

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

2019-11-20 21:01:36
字體:
來源:轉載
供稿:網友

前言
SeaJS是一個遵循CommonJS規范的JavaScript模塊加載框架,可以實現JavaScript的模塊化開發及加載機制。與jQuery等JavaScript框架不同,SeaJS不會擴展封裝語言特性,而只是實現JavaScript的模塊化及按模塊加載。SeaJS的主要目的是令JavaScript開發模塊化并可以輕松愉悅進行加載,將前端工程師從繁重的JavaScript文件及對象依賴處理中解放出來,可以專注于代碼本身的邏輯。SeaJS可以與jQuery這類框架完美集成。使用SeaJS可以提高JavaScript代碼的可讀性和清晰度,解決目前JavaScript編程中普遍存在的依賴關系混亂和代碼糾纏等問題,方便代碼的編寫和維護。
SeaJS的作者是淘寶前端工程師玉伯。
SeaJS本身遵循KISS(Keep It Simple, Stupid)理念進行開發,其本身僅有個位數的API,因此學習起來毫無壓力。在學習SeaJS的過程中,處處能感受到KISS原則的精髓――僅做一件事,做好一件事。
本文首先通過一個例子直觀對比傳統JavaScript編程和使用SeaJS的模塊化JavaScript編程,然后詳細討論SeaJS的使用方法,最后給出一些與SeaJS相關的資料。

傳統模式 vs SeaJS模塊化
假設我們現在正在開發一個Web應用TinyApp,我們決定在TinyApp中使用jQuery框架。TinyApp的首頁會用到module1.js,module1.js依賴module2.js和module3.js,同時module3.js依賴module4.js。
傳統開發
使用傳統的開發方法,各個js文件代碼如下:

復制代碼 代碼如下:
//module1.js
var module1 = {
    run: function() {
        return $.merge(['module1'], $.merge(module2.run(), module3.run()));
    }
}

//module2.js
var module2 = {
    run: function() {
        return ['module2'];
    }
}

//module3.js
var module3 = {
    run: function() {
        return $.merge(['module3'], module4.run());
    }
}

//module4.js
var module4 = {
    run: function() {
        return ['module4'];
    }
}

此時index.html需要引用module1.js及其所有下層依賴(注意順序):
復制代碼 代碼如下:
<!DOCTYPE HTML>
<html lang="zh-CN">
<head>
    <meta charset="UTF-8">
    <title>TinyApp</title>
    <script src="./jquery-min.js"></script>
    <script src="./module4.js"></script>
    <script src="./module2.js"></script>
    <script src="./module3.js"></script>
    <script src="./module1.js"></script>
</head>
<body>
    <p class="content"></p>
    <script>
        $('.content').html(module1.run());
    </script>
</body>
</html>

隨著項目的進行,js文件會越來越多,依賴關系也會越來越復雜,使得js代碼和html里的script列表往往變得難以維護。
SeaJS模塊化開發
下面看看如何使用SeaJS實現相同的功能。
首先是index.html:
復制代碼 代碼如下:
<!DOCTYPE HTML>
<html lang="zh-CN">
<head>
    <meta charset="UTF-8">
    <title>TinyApp</title>
</head>
<body>
    <p class="content"></p>
    <script src="./sea.js"></script>
    <script>
        seajs.use('./init', function(init) {
            init.initPage();
        });
    </script>
</body>
</html>

可以看到html頁面不再需要引入所有依賴的js文件,而只是引入一個sea.js,sea.js會處理所有依賴,加載相應的js文件,加載策略可以選擇在渲染頁面時一次性加載所有js文件,也可以按需加載(用到時才加載響應js),具體加載策略使用方法下文討論。
index.html加載了init模塊,并使用此模塊的initPage方法初始化頁面數據,這里先不討論代碼細節。
下面看一下模塊化后JavaScript的寫法:
復制代碼 代碼如下:
//jquery.js
define(function(require, exports, module) = {

    //原jquery.js代碼...

    module.exports = $.noConflict(true);
});

//init.js
define(function(require, exports, module) = {
    var $ = require('jquery');
    var m1 = require('module1');

    exports.initPage = function() {
        $('.content').html(m1.run());   
    }
});

//module1.js
define(function(require, exports, module) = {
    var $ = require('jquery');
    var m2 = require('module2');
    var m3 = require('module3');

    exports.run = function() {
        return $.merge(['module1'], $.merge(m2.run(), m3.run()));   
    }
});

//module2.js
define(function(require, exports, module) = {
    exports.run = function() {
        return ['module2'];
    }
});

//module3.js
define(function(require, exports, module) = {
    var $ = require('jquery');
    var m4 = require('module4');

    exports.run = function() {
        return $.merge(['module3'], m4.run());   
    }
});

//module4.js
define(function(require, exports, module) = {
    exports.run = function() {
        return ['module4'];
    }
});

乍看之下代碼似乎變多變復雜了,這是因為這個例子太簡單,如果是大型項目,SeaJS代碼的優勢就會顯現出來。不過從這里我們還是能窺探到一些SeaJS的特性:
一是html頁面不用再維護冗長的script標簽列表,只要引入一個sea.js即可。
二是js代碼以模塊進行組織,各個模塊通過require引入自己依賴的模塊,代碼清晰明了。
通過這個例子朋友們應該對SeaJS有了一個直觀的印象,下面本文具體討論SeaJS的使用。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
欧美日韩国产综合新一区| 清纯唯美亚洲综合| 一本一道久久a久久精品逆3p| 欧美福利视频网站| 日韩激情视频在线播放| 欧美性猛交xxx| 91久久精品视频| 亚洲精品国产精品国产自| 日韩精品视频在线观看免费| 精品国产老师黑色丝袜高跟鞋| 91精品国产免费久久久久久| 欧美在线视频免费| 精品性高朝久久久久久久| 国产精品网红福利| 在线观看国产欧美| 欧美一区二三区| 午夜欧美大片免费观看| 色噜噜狠狠狠综合曰曰曰88av| 欧美电影在线观看网站| 日韩日本欧美亚洲| 亚洲天天在线日亚洲洲精| 91精品国产乱码久久久久久久久| 精品综合久久久久久97| 久久精品精品电影网| www国产精品视频| 精品久久久久人成| 欧美激情a∨在线视频播放| 精品久久久久久中文字幕| 欧美黄色片在线观看| 8x拔播拔播x8国产精品| 国产精品黄页免费高清在线观看| 欧美与黑人午夜性猛交久久久| 97成人精品视频在线观看| 一本色道久久综合狠狠躁篇怎么玩| 亚洲欧美日韩精品久久奇米色影视| 美女扒开尿口让男人操亚洲视频网站| 成人午夜激情免费视频| 亚洲欧美日韩中文视频| 日韩欧美在线免费| 黄色一区二区在线观看| 亚洲天堂网在线观看| 中文字幕亚洲欧美日韩高清| 日韩成人高清在线| 欧美黄色免费网站| 97av视频在线| 久久夜色精品亚洲噜噜国产mv| 激情成人在线视频| 亚洲第一页中文字幕| 欧美二区在线播放| 国产亚洲免费的视频看| 国产精品吊钟奶在线| 国产精品jizz在线观看麻豆| 日韩在线视频线视频免费网站| xxxxx成人.com| 色伦专区97中文字幕| 色综合五月天导航| 国产视频久久久久| 国产精品美女网站| 亚洲天堂2020| 欧美日本啪啪无遮挡网站| 国产精品吴梦梦| 色综合色综合久久综合频道88| 国产精品福利在线观看网址| 亚洲精品自产拍| 91精品免费久久久久久久久| 欧美精品在线看| 92裸体在线视频网站| 日韩精品在线电影| 俺去了亚洲欧美日韩| 成人乱色短篇合集| 亚洲影院色在线观看免费| 欧洲美女免费图片一区| 国产福利成人在线| 精品精品国产国产自在线| 91wwwcom在线观看| 亚洲精品福利资源站| 国产做受69高潮| 亚洲欧洲成视频免费观看| 欧美在线播放视频| 欧美日韩亚洲国产一区| 亚洲国产精品久久精品怡红院| 国产精品入口免费视频一| 最近2019中文免费高清视频观看www99| 久久国产精品免费视频| 国产精品福利在线观看网址| 亚洲精品电影网在线观看| 亚洲天堂2020| 亚洲国产精久久久久久| 亚洲精品中文字幕有码专区| 最新91在线视频| 热久久美女精品天天吊色| 日韩中文综合网| 久久久久成人精品| 91青草视频久久| 日韩亚洲欧美成人| 亚洲免费一在线| 久久久亚洲国产天美传媒修理工| 欧美一级大片在线观看| 欧美猛交ⅹxxx乱大交视频| 日韩久久精品电影| 欧美日韩精品二区| xxxx欧美18另类的高清| 91黑丝高跟在线| 亚洲欧美另类自拍| 精品福利在线视频| 成人免费在线视频网址| 国产精品人成电影| 欧美巨乳在线观看| 日韩电视剧在线观看免费网站| 宅男66日本亚洲欧美视频| 国产丝袜精品第一页| 色综合久久天天综线观看| 欧美在线观看一区二区三区| 欧美视频在线免费看| 国产亚洲精品91在线| 日韩av中文字幕在线播放| 亚洲精品久久久久中文字幕欢迎你| 国产一区二区日韩| 日韩电影免费观看中文字幕| 日韩高清电影免费观看完整版| 欧美精品18videos性欧| 亚洲视频综合网| 欧美激情手机在线视频| 国产精品吊钟奶在线| 欧美在线亚洲在线| 69av成年福利视频| 久久亚洲精品网站| 亚洲激情自拍图| 91亚洲永久免费精品| 亚洲国模精品一区| 伊人伊成久久人综合网站| 国产精品亚洲一区二区三区| 国产一区av在线| 欧美日韩一区二区三区在线免费观看| 久久久久久久999精品视频| 日韩中文字幕国产精品| 国内免费久久久久久久久久久| 欧美理论电影在线播放| 久久国产精品久久精品| 国产日本欧美一区二区三区在线| 欧美日韩国产一区中文午夜| 亚洲最大的网站| 久久影视三级福利片| 亚洲男人天堂网站| 亚洲国产成人91精品| 91伊人影院在线播放| 欧美日韩中文字幕综合视频| 国产在线观看一区二区三区| 久久久精品国产一区二区| 欧美黑人性视频| 国内精品视频一区| 国产97在线|日韩| 91在线视频一区| 亚洲欧美一区二区三区在线| 亚洲专区国产精品| 国产视频福利一区| 久久av资源网站| 国产精品第一区| 亚洲国产精久久久久久| 午夜精品一区二区三区av| 日韩经典第一页| 欧美xxxx18国产| 亚洲国产成人精品女人久久久| 亚洲成人aaa|