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

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

 更新時(shí)間:2014年03月03日 08:52:34   作者:  
這篇文章主要介紹了SeaJS入門教程,講述了SeaJS的由來(lái),JavaScript傳統(tǒng)開(kāi)發(fā)模式和模塊化開(kāi)發(fā)的對(duì)比,需要的朋友可以參考下

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

傳統(tǒng)模式 vs SeaJS模塊化
假設(shè)我們現(xiàn)在正在開(kāi)發(fā)一個(gè)Web應(yīng)用TinyApp,我們決定在TinyApp中使用jQuery框架。TinyApp的首頁(yè)會(huì)用到module1.js,module1.js依賴module2.js和module3.js,同時(shí)module3.js依賴module4.js。
傳統(tǒng)開(kāi)發(fā)
使用傳統(tǒng)的開(kāi)發(fā)方法,各個(gè)js文件代碼如下:

復(fù)制代碼 代碼如下:
//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'];
    }
}

此時(shí)index.html需要引用module1.js及其所有下層依賴(注意順序):
復(fù)制代碼 代碼如下:
<!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>

隨著項(xiàng)目的進(jìn)行,js文件會(huì)越來(lái)越多,依賴關(guān)系也會(huì)越來(lái)越復(fù)雜,使得js代碼和html里的script列表往往變得難以維護(hù)。
SeaJS模塊化開(kāi)發(fā)
下面看看如何使用SeaJS實(shí)現(xiàn)相同的功能。
首先是index.html:
復(fù)制代碼 代碼如下:
<!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頁(yè)面不再需要引入所有依賴的js文件,而只是引入一個(gè)sea.js,sea.js會(huì)處理所有依賴,加載相應(yīng)的js文件,加載策略可以選擇在渲染頁(yè)面時(shí)一次性加載所有js文件,也可以按需加載(用到時(shí)才加載響應(yīng)js),具體加載策略使用方法下文討論。
index.html加載了init模塊,并使用此模塊的initPage方法初始化頁(yè)面數(shù)據(jù),這里先不討論代碼細(xì)節(jié)。
下面看一下模塊化后JavaScript的寫法:
復(fù)制代碼 代碼如下:
//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'];
    }
});

乍看之下代碼似乎變多變復(fù)雜了,這是因?yàn)檫@個(gè)例子太簡(jiǎn)單,如果是大型項(xiàng)目,SeaJS代碼的優(yōu)勢(shì)就會(huì)顯現(xiàn)出來(lái)。不過(guò)從這里我們還是能窺探到一些SeaJS的特性:
一是html頁(yè)面不用再維護(hù)冗長(zhǎng)的script標(biāo)簽列表,只要引入一個(gè)sea.js即可。
二是js代碼以模塊進(jìn)行組織,各個(gè)模塊通過(guò)require引入自己依賴的模塊,代碼清晰明了。
通過(guò)這個(gè)例子朋友們應(yīng)該對(duì)SeaJS有了一個(gè)直觀的印象,下面本文具體討論SeaJS的使用。

相關(guān)文章

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

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

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

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

    這篇文章主要介紹了SeaJS入門教程,講述了SeaJS的由來(lái),JavaScript傳統(tǒng)開(kāi)發(fā)模式和模塊化開(kāi)發(fā)的對(duì)比,需要的朋友可以參考下
    2014-03-03
  • 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
  • Vue實(shí)現(xiàn)圖片懶加載的多種方法詳解

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

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

    seajs中最常用的7個(gè)功能、配置示例

    這篇文章主要介紹了seajs中最常用的7個(gè)功能、配置,結(jié)合實(shí)例形式簡(jiǎn)單分析了seajs中常用的項(xiàng)目配置、模塊加載、定義、獲取等操作技巧,需要的朋友可以參考下
    2017-10-10
  • seaJs使用心得之exports與module.exports的區(qū)別實(shí)例分析

    seaJs使用心得之exports與module.exports的區(qū)別實(shí)例分析

    這篇文章主要介紹了seaJs使用心得之exports與module.exports的區(qū)別,結(jié)合實(shí)例形式分析了exports與module.exports具體功能、使用方法及相關(guān)操作注意事項(xiàng),需要的朋友可以參考下
    2017-10-10
  • seajs學(xué)習(xí)之模塊的依賴加載及模塊API的導(dǎo)出

    seajs學(xué)習(xí)之模塊的依賴加載及模塊API的導(dǎo)出

    SeaJS是一個(gè)遵循 CommonJS 規(guī)范的模塊加載框架,可用來(lái)輕松愉悅地加載任意JavaScript模塊和css模塊樣式。SeaJS接口和方法也非常少,SeaJS 就兩個(gè)核心:模塊定義和模塊的加載及依賴關(guān)系。本文將詳細(xì)介紹模塊的依賴加載及模塊API的導(dǎo)出,有需要的朋友們可以參考借鑒。
    2016-10-10
  • sea.js常用的api簡(jiǎn)易文檔

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

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

    把jQuery的類、插件封裝成seajs的模塊的方法

    這篇文章主要介紹了把jQuery的類、插件封裝成seajs的模塊的方法,需要的朋友可以參考下
    2014-03-03
  • 詳解Sea.js中Module.exports和exports的區(qū)別

    詳解Sea.js中Module.exports和exports的區(qū)別

    最近在看Seajs時(shí),看到了exports.doSomething和module.exports,想對(duì)這兩者的區(qū)別一探究竟。所以下面這篇文章主要介紹了Sea.js中Module.exports和exports的區(qū)別,需要的朋友可以參考借鑒,一起來(lái)看看吧。
    2017-02-02

最新評(píng)論