国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 語言 > JavaScript > 正文

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

2024-05-06 16:01:56
字體:
來源:轉載
供稿:網友
這篇文章主要介紹了SeaJS入門教程,講述了SeaJS的由來,JavaScript傳統(tǒng)開發(fā)模式和模塊化開發(fā)的對比,需要的朋友可以參考下

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

傳統(tǒng)模式 vs SeaJS模塊化
假設我們現(xiàn)在正在開發(fā)一個Web應用TinyApp,我們決定在TinyApp中使用jQuery框架。TinyApp的首頁會用到module1.js,module1.js依賴module2.js和module3.js,同時module3.js依賴module4.js。
傳統(tǒng)開發(fā)
使用傳統(tǒng)的開發(fā)方法,各個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></p>
    <script>
        $('.content').html(module1.run());
    </script>
</body>
</html>


隨著項目的進行,js文件會越來越多,依賴關系也會越來越復雜,使得js代碼和html里的script列表往往變得難以維護。
SeaJS模塊化開發(fā)
下面看看如何使用SeaJS實現(xiàn)相同的功能。
首先是index.html:

復制代碼 代碼如下:

<!DOCTYPE HTML>
<html lang="zh-CN">
<head>
    <meta charset="UTF-8">
    <title>TinyApp</title>
</head>
<body>
    <p></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方法初始化頁面數(shù)據(jù),這里先不討論代碼細節(jié)。
下面看一下模塊化后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代碼的優(yōu)勢就會顯現(xiàn)出來。不過從這里我們還是能窺探到一些SeaJS的特性:
一是html頁面不用再維護冗長的script標簽列表,只要引入一個sea.js即可。
二是js代碼以模塊進行組織,各個模塊通過require引入自己依賴的模塊,代碼清晰明了。
通過這個例子朋友們應該對SeaJS有了一個直觀的印象,下面本文具體討論SeaJS的使用。

發(fā)表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發(fā)表

圖片精選

主站蜘蛛池模板: 印江| 福海县| 洞口县| 新宾| 定远县| 临江市| 铁岭市| 迁西县| 红原县| 靖安县| 清水县| 泰和县| 永吉县| 华安县| 田东县| 安岳县| 江达县| 大城县| 卢湾区| 永顺县| 东源县| 儋州市| 普兰店市| 顺义区| 乌鲁木齐县| 珠海市| 会泽县| 吴堡县| 都昌县| 西和县| 武夷山市| 大安市| 广安市| 宁波市| 古浪县| 余姚市| 饶阳县| 华亭县| 佛冈县| 深州市| 汝阳县|