国产xxxx99真实实拍_久久不雅视频_高清韩国a级特黄毛片_嗯老师别我我受不了了小说

資訊專欄INFORMATION COLUMN

前端優(yōu)化:RequireJS Optimizer 的使用和配置方法

Alan / 1500人閱讀

摘要:是自帶的前端優(yōu)化工具,可以對項目中的和代碼使用或者進(jìn)行壓縮合并。這篇文章介紹的使用和配置方法,幫助大家解決使用中碰到的問題。對腳本的優(yōu)化支持目前流行的和兩種壓縮方式,需要環(huán)境支持,而則需要環(huán)境。定義要被優(yōu)化的模塊數(shù)組。

RequireJS Optimizer 是 RequireJS 自帶的前端優(yōu)化工具,可以對 RequireJS 項目中的JavaScript和CSS 代碼使用?UglifyJS 或者?Closure Compiler 進(jìn)行壓縮合并。這篇文章介紹RequireJS Optimizer 的使用和配置方法,幫助大家解決使用中碰到的問題。

RequireJS Optimizer 對腳本的優(yōu)化支持目前流行的?UglifyJS 和 Closure Compiler 兩種壓縮方式,UglifyJS 需要 NodeJS 環(huán)境支持,而?Closure Compiler 則需要 Java 環(huán)境。這篇文章是以運行于 NodeJS 的 UglifyJS 來優(yōu)化的,這也是?RequireJS Optimizer 默認(rèn)的壓縮方法。

首先需要安裝?Node 0.4.0,然后下載 r.js,下載好以后就可以在命令行里對前端代碼進(jìn)行優(yōu)化了。r.js的參數(shù)傳遞使用方式,一是直接加在命令行后面,如下:

node r.js -o baseUrl=. paths.jquery=some/other/jquery name=main out=main-built.js

二是新建一個配置文件,例如 build.js(推薦使用這種方式),這樣配置更方便,如下:

node r.js -o build.js

build.js 的配置代碼如下:

{
    baseUrl: "../js",
    dir: "../dist",
    optimize: "uglify",
    optimizeCss: "standard.keepLines",
    mainConfigFile: "../js/main.js",
    removeCombined: true,
    fileExclusionRegExp: /^./,
    modules: [
        {
            name: "app/dispatcher",
        },
        {
            name: "app/in-storage",
            exclude: [
                "jquery",
                "app/common",
                "pkg/DatePicker/app"
            ]
        }
    ]
}
基本參數(shù)介紹

appDir

應(yīng)用程序的最頂層目錄。可選的,如果設(shè)置了的話,r.js會認(rèn)為腳本在這個路徑的子目錄中,應(yīng)用程序的文件都會被拷貝到輸出目錄(dir 定義的路徑)。如果不設(shè)置,則使用下面的 baseUrl 路徑。

baseUrl

  默認(rèn)情況下,所有的模塊都是相對于這個路徑的。如果沒有設(shè)置,則模塊的加載是相對于 build 文件所在的目錄。另外,如果設(shè)置了appDir,那么 baseUrl 應(yīng)該定義為相對于 appDir 的路徑。

dir

輸出目錄的路徑。如果不設(shè)置,則默認(rèn)為和 build 文件同級的 build 目錄。

optimize

JavaScript 代碼優(yōu)化方式??稍O(shè)置的值:

-   "uglify:使用?UglifyJS 壓縮代碼,默認(rèn)值;
-   "uglify2":使用?2.1.2+ 版本進(jìn)行壓縮;
-   "closure": 使用?Google"s Closure Compiler 進(jìn)行壓縮合并,需要 Java 環(huán)境;
-   "closure.keepLines":使用?Closure Compiler 進(jìn)行壓縮合并并保留換行;
-   "none":不做壓縮合并;

optimizeCss

CSS 代碼優(yōu)化方式,可選的值有:

-   "standard":標(biāo)準(zhǔn)的壓縮方式;
-   "standard.keepLines":保留換行;
-   "standard.keepComments":保留注釋;
-   "standard.keepComments.keepLines":保留換行;
-   "none":不壓縮;

mainConfigFile

如果不想重復(fù)定義的話,可以使用這個參數(shù)配置 RequireJS 的配置文件路徑。

removeCombined

刪除之前壓縮合并的文件,默認(rèn)值 false。

fileExclusionRegExp

要排除的文件的正則匹配的表達(dá)式。

modules

定義要被優(yōu)化的模塊數(shù)組。每一項是模塊優(yōu)化的配置,常用的幾個參數(shù)如下:

- `name:`模塊名;

- `include:`額外引入的模塊,`create:`如果不存在,是否創(chuàng)建。默認(rèn)`false`;

- `exclude:`要排除的模塊。有些模塊有公共的依賴模塊,在合并的時候每個都會壓縮進(jìn)去,例如一些基礎(chǔ)庫。使用 exclude 就可以把這些模塊在壓縮在一個更早之前加載的模塊中,其它模塊不用重復(fù)引入。

其它事項

RequireJS 配置也可以放到 RequireJS Optimizer?配置文件里面,例如:

{
    baseUrl: "../js",
    dir: "../dist",
    optimize: "uglify",
    optimizeCss: "standard.keepLines",
    removeCombined: true,
    fileExclusionRegExp: /^./,
    modules: [
        {
            name: "app/dispatcher",
        },
        {
            name: "app/in-storage",
            exclude: [
                "jquery",
                "app/common",
                "pkg/DatePicker/app"
            ]
        }
    ],
    paths: {
        jquery: "lib/jquery",
        underscore: "lib/underscore",
        backbone: "lib/backbone/backbone",
        backboneLocalstorage: "lib/backbone/backbone.localStorage",
        text: "lib/require/text"
    },
    shim: {
        underscore: {
            exports: "_"
        },
        backbone: {
            deps: [
                "underscore",
                "jquery"
            ],
            exports: "Backbone"
        },
        backboneLocalstorage: {
            deps: ["backbone"],
            exports: "Store"
        }
    }
}

RequireJS Optimizer 的配置參數(shù)還有很多,完整的參數(shù)介紹可以看這里:

example.build.js

為方便運行,可以新建一個批處理文件:

@echo off 

echo build...
e:
cd E:SCMSRCscm-html
ew-scm-html	ools

node r.js -o build.js

echo Press any key to exit! 
echo. & pause

注意事項:RequireJS Optimizer 只支持使用 require 和 define 語法定義的模塊,因此下面這種通過變量定義的方式是不支持的:

var mods = someCondition ? ["a", "b"] : ["c", "d"];
require(mods);

而如果是這樣定義則可以:

require(["a", "b"]);

或者:

define(["a", "b"], function (a, b) {});
進(jìn)一步優(yōu)化

使用 r.js 優(yōu)化后的代碼可以使用 almond?來加載。almond 是一個輕量的 AMD 加載器,提供了最基礎(chǔ)的 AMD API 實現(xiàn)以及模塊加載功能。almond 只有不到 400 行代碼,要比 RequireJS 小很多??梢允褂?r.js 把 almond 一起合并到業(yè)務(wù)代碼的前面,如下:

(function () {
    //almond will be here
    //main and its nested dependencies will be here
}());

almond 特別適合使用 AMD 的網(wǎng)站或應(yīng)用,但也有一些限制:

所有的模塊編譯為一個文件,沒有動態(tài)的加載;

所有的模塊都需要在 define() 定義 ID 和依賴,這個?RequireJS Optimizer 會處理;

只能有一個?requirejs.config() 或者 require.config() 調(diào)用;

不能使用 Require JS 多版本功能;

不能使用?require.toUrl() 或者 require.nameToUrl();

不能使用?packages/packagePaths 配置。

如果你的項目中沒有這些問題的話,可以放心使用 almond 進(jìn)行加載。

?

via 夢想天空

文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。

轉(zhuǎn)載請注明本文地址:http://m.specialneedsforspecialkids.com/yun/110836.html

相關(guān)文章

  • requirejs插件介紹與制作

    摘要:一句化即它是插件的插件,作者事后才發(fā)現(xiàn)有這么一個插件繞了不少彎路。這里的主要是為了保存這段內(nèi)容用于打包使用。免費領(lǐng)取驗證碼內(nèi)容安全短信發(fā)送直播點播體驗包及云服務(wù)器等套餐更多網(wǎng)易技術(shù)產(chǎn)品運營經(jīng)驗分享請訪問網(wǎng)易云社區(qū)。文章來源網(wǎng)易云社區(qū) 本文由作者鄭海波授權(quán)網(wǎng)易云社區(qū)發(fā)布。 前言我這里就不介紹requirejs了, 簡而言之: requirejs是支持AMD規(guī)范的模塊加載器, 事實上它也是...

    shinezejian 評論0 收藏0
  • 使用require.js構(gòu)建優(yōu)化項目實踐

    摘要:嘗試用自己主頁的簡單代碼構(gòu)建優(yōu)化下。存放和,放需要構(gòu)建的項目代碼,為構(gòu)建目標(biāo)文件夾。我另外一篇博文構(gòu)建優(yōu)化有簡單說了下,構(gòu)建的命令,其實上的官網(wǎng),看有更詳細(xì)的內(nèi)容。 嘗試用自己主頁的簡單代碼構(gòu)建優(yōu)化下。 在文件夾requirejs-optimizer下新建三個文件夾:tools,www和www-built。tools存放r.js和build.js,www放需要構(gòu)建的項目代碼,www-b...

    anRui 評論0 收藏0
  • 前端構(gòu)建】RequireJS及其優(yōu)化工具

    摘要:介紹一款模塊加載工具的入門,并且重點介紹其優(yōu)化工具。發(fā)布目錄項目源代碼工具目錄,例如構(gòu)建工具等。另外,前端代碼發(fā)布前都會進(jìn)行壓縮,使文件足夠小。原來是因為里了,所以優(yōu)化工具把也合并進(jìn)來了。而優(yōu)化工具要用好,要多嘗試他們的配置選項。 前端變化太快,如今RequireJS已經(jīng)無法吸引眼球了。介紹一款模塊加載工具:RequireJS的入門,并且重點介紹其優(yōu)化工具。 一、RequireJS簡介...

    Loong_T 評論0 收藏0
  • 前端性能優(yōu)化——加載頁面靜態(tài)資源(入門級別)

    摘要:服務(wù)器可以在與每次客戶端傳送的字段進(jìn)行比較,如果相等,則表示未修改,響應(yīng)反之,則表示已修改,響應(yīng)狀態(tài)碼,返回新資源。 最近一直在準(zhǔn)備面試,接觸了一些性能優(yōu)化方面的知識,前端性能優(yōu)化主要從兩個方面進(jìn)行: 1.加載頁面和靜態(tài)資源;2.頁面渲染; 這篇文章主要講第一點: 加載頁面和靜態(tài)資源 加載頁面和靜態(tài)資源主要可以從三個角度進(jìn)行: 靜態(tài)資源的合并、壓縮(http2.0時代有變) 靜態(tài)資源...

    moven_j 評論0 收藏0
  • FIS

    摘要:執(zhí)行這個指令,對項目進(jìn)行發(fā)布。尋找文件,放在文件底下尋找文件,放在文件底下中語法拓展,我們可以將表示除拓展名以外的任何字符。告知,需要制作精靈圖。替換內(nèi)置打包工具中的路徑不會自動修改。配置規(guī)范規(guī)范插件入口,引入文件方式不同。 Fis簡介 一個工程化的工具,主要用來處理前端的項目。作用:代碼合并,代碼壓縮,資源定義,資源嵌套等等。 fis 是基于流的處理,fis有自己的一個流處理過程: ...

    mdluo 評論0 收藏0

發(fā)表評論

0條評論

最新活動
閱讀需要支付1元查看
<