摘要:是自帶的前端優(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
摘要:一句化即它是插件的插件,作者事后才發(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ī)范的模塊加載器, 事實上它也是...
摘要:嘗試用自己主頁的簡單代碼構(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...
摘要:介紹一款模塊加載工具的入門,并且重點介紹其優(yōu)化工具。發(fā)布目錄項目源代碼工具目錄,例如構(gòu)建工具等。另外,前端代碼發(fā)布前都會進(jìn)行壓縮,使文件足夠小。原來是因為里了,所以優(yōu)化工具把也合并進(jìn)來了。而優(yōu)化工具要用好,要多嘗試他們的配置選項。 前端變化太快,如今RequireJS已經(jīng)無法吸引眼球了。介紹一款模塊加載工具:RequireJS的入門,并且重點介紹其優(yōu)化工具。 一、RequireJS簡介...
摘要:服務(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)資源...
閱讀 3067·2021-11-23 09:51
閱讀 1050·2021-09-02 15:21
閱讀 3014·2019-08-30 13:56
閱讀 1838·2019-08-29 14:12
閱讀 716·2019-08-29 13:53
閱讀 1676·2019-08-29 11:32
閱讀 1337·2019-08-29 11:25
閱讀 1501·2019-08-28 17:51