Microsoft Ajax MinifierによるJavascriptコードとCSSの最小化

JavaScriptファイルやCSSなど、Webページに関連付けられた大きなリソースをダウンロードすると、ページの読み込み速度に影響するだけでなく、サーバーからクライアントブラウザーに渡されるトラフィックも増加します。 後者の状況は、制限された関税との関連で、または所定量の送信データを使用してサイトをホスティングに配置する場合に特に重要です。

余分なバイトを処理する1つの方法は、サーバー上のデータを圧縮し、gzipストリームをブラウザーに転送することです。ブラウザーは、ページのレンダリング中に既に解凍します。 この方法の説明は、この記事には含まれていません。 付随するWebページファイルから重要でない文字をすべて削除することでデータを削減する方法についてお話したいと思います:JavaScriptとCSS-最小化。

クライアント関数とサイトスタイルを記述する場合、プログラマー/デザイナーはスペースまたはタブを使用した改行を使用して、テキストの読みやすさとメンテナンスの容易さを向上させます。 コードが特定の言語に対して通常の方法で構造化およびフォーマットされている場合、100行のファイルの途中で発生したエラーをキャッチする方が便利です。 CSSルールとJavaScript関数はまったく同じように機能します。すべてを1行に配置するか、各ルールを別の行に配置します。

サイトがインターネットにアクセスするとき、これらの読みやすさは単に不要です。 一方、最小化が必要なファイルがいくつかある場合、読み取り可能なファイルを最小化された形式に変換するプロセスは簡単な作業ではなく、自動化が必要です。

2010年2月16日に、MicrosoftはMicrosoft Ajax Minifierと呼ばれるユーティリティの4番目のバージョンをリリースしました。 このユーティリティは、コマンドラインまたは独自の.NETプログラム(この記事には含まれていません)から、またはMicrosoft Visual Studioでの開発時にMSBuildシステムを使用して使用できます(VS 2008で作業しています)。

Microsoft Ajax Minifierパッケージをインストールすると、ASP.NET Webアプリケーションなどの埋め込みWebプロジェクトに基づいて作成されたプロジェクトにMSBuildのタスクを追加できるようになります。 Webサイトとしてスタジオに追加されたサイトは、MSBuildタスクがインストールされる.projファイルがないため、適切ではありません。
  1. サイトプロジェクトのコンテキストメニューで[ プロジェクトアンロード ]を選択します。
  2. すでに出荷されているプロジェクトのコンテキストメニューで、[ プロジェクト名の編集 ]を選択します。 Visual Studioは、 * .projファイルを編集用に表示します。
  3. <Project>タグ内に次のコードを記述します。
    < Import Project ="$(MSBuildExtensionsPath)\Microsoft\MicrosoftAjax\ajaxmin.tasks" /> < Target Name ="AfterBuild" > < ItemGroup > < JS Include ="**\*.js" Exclude ="**\*.min.js;Scripts\*.js" /> </ ItemGroup > < ItemGroup > < CSS Include ="**\*.css" Exclude ="**\*.min.css" /> </ ItemGroup > < AjaxMin JsSourceFiles ="@(JS)" JsSourceExtensionPattern ="\.js$" JsTargetExtension =".min.js" CssSourceFiles ="@(CSS)" CssSourceExtensionPattern ="\.css$" CssTargetExtension =".min.css" /> </ Target > * This source code was highlighted with Source Code Highlighter .
    1. < Import Project ="$(MSBuildExtensionsPath)\Microsoft\MicrosoftAjax\ajaxmin.tasks" /> < Target Name ="AfterBuild" > < ItemGroup > < JS Include ="**\*.js" Exclude ="**\*.min.js;Scripts\*.js" /> </ ItemGroup > < ItemGroup > < CSS Include ="**\*.css" Exclude ="**\*.min.css" /> </ ItemGroup > < AjaxMin JsSourceFiles ="@(JS)" JsSourceExtensionPattern ="\.js$" JsTargetExtension =".min.js" CssSourceFiles ="@(CSS)" CssSourceExtensionPattern ="\.css$" CssTargetExtension =".min.css" /> </ Target > * This source code was highlighted with Source Code Highlighter .
    2. < Import Project ="$(MSBuildExtensionsPath)\Microsoft\MicrosoftAjax\ajaxmin.tasks" /> < Target Name ="AfterBuild" > < ItemGroup > < JS Include ="**\*.js" Exclude ="**\*.min.js;Scripts\*.js" /> </ ItemGroup > < ItemGroup > < CSS Include ="**\*.css" Exclude ="**\*.min.css" /> </ ItemGroup > < AjaxMin JsSourceFiles ="@(JS)" JsSourceExtensionPattern ="\.js$" JsTargetExtension =".min.js" CssSourceFiles ="@(CSS)" CssSourceExtensionPattern ="\.css$" CssTargetExtension =".min.css" /> </ Target > * This source code was highlighted with Source Code Highlighter .
    3. < Import Project ="$(MSBuildExtensionsPath)\Microsoft\MicrosoftAjax\ajaxmin.tasks" /> < Target Name ="AfterBuild" > < ItemGroup > < JS Include ="**\*.js" Exclude ="**\*.min.js;Scripts\*.js" /> </ ItemGroup > < ItemGroup > < CSS Include ="**\*.css" Exclude ="**\*.min.css" /> </ ItemGroup > < AjaxMin JsSourceFiles ="@(JS)" JsSourceExtensionPattern ="\.js$" JsTargetExtension =".min.js" CssSourceFiles ="@(CSS)" CssSourceExtensionPattern ="\.css$" CssTargetExtension =".min.css" /> </ Target > * This source code was highlighted with Source Code Highlighter .
    4. < Import Project ="$(MSBuildExtensionsPath)\Microsoft\MicrosoftAjax\ajaxmin.tasks" /> < Target Name ="AfterBuild" > < ItemGroup > < JS Include ="**\*.js" Exclude ="**\*.min.js;Scripts\*.js" /> </ ItemGroup > < ItemGroup > < CSS Include ="**\*.css" Exclude ="**\*.min.css" /> </ ItemGroup > < AjaxMin JsSourceFiles ="@(JS)" JsSourceExtensionPattern ="\.js$" JsTargetExtension =".min.js" CssSourceFiles ="@(CSS)" CssSourceExtensionPattern ="\.css$" CssTargetExtension =".min.css" /> </ Target > * This source code was highlighted with Source Code Highlighter .
    5. < Import Project ="$(MSBuildExtensionsPath)\Microsoft\MicrosoftAjax\ajaxmin.tasks" /> < Target Name ="AfterBuild" > < ItemGroup > < JS Include ="**\*.js" Exclude ="**\*.min.js;Scripts\*.js" /> </ ItemGroup > < ItemGroup > < CSS Include ="**\*.css" Exclude ="**\*.min.css" /> </ ItemGroup > < AjaxMin JsSourceFiles ="@(JS)" JsSourceExtensionPattern ="\.js$" JsTargetExtension =".min.js" CssSourceFiles ="@(CSS)" CssSourceExtensionPattern ="\.css$" CssTargetExtension =".min.css" /> </ Target > * This source code was highlighted with Source Code Highlighter .
    6. < Import Project ="$(MSBuildExtensionsPath)\Microsoft\MicrosoftAjax\ajaxmin.tasks" /> < Target Name ="AfterBuild" > < ItemGroup > < JS Include ="**\*.js" Exclude ="**\*.min.js;Scripts\*.js" /> </ ItemGroup > < ItemGroup > < CSS Include ="**\*.css" Exclude ="**\*.min.css" /> </ ItemGroup > < AjaxMin JsSourceFiles ="@(JS)" JsSourceExtensionPattern ="\.js$" JsTargetExtension =".min.js" CssSourceFiles ="@(CSS)" CssSourceExtensionPattern ="\.css$" CssTargetExtension =".min.css" /> </ Target > * This source code was highlighted with Source Code Highlighter .
    7. < Import Project ="$(MSBuildExtensionsPath)\Microsoft\MicrosoftAjax\ajaxmin.tasks" /> < Target Name ="AfterBuild" > < ItemGroup > < JS Include ="**\*.js" Exclude ="**\*.min.js;Scripts\*.js" /> </ ItemGroup > < ItemGroup > < CSS Include ="**\*.css" Exclude ="**\*.min.css" /> </ ItemGroup > < AjaxMin JsSourceFiles ="@(JS)" JsSourceExtensionPattern ="\.js$" JsTargetExtension =".min.js" CssSourceFiles ="@(CSS)" CssSourceExtensionPattern ="\.css$" CssTargetExtension =".min.css" /> </ Target > * This source code was highlighted with Source Code Highlighter .
    8. < Import Project ="$(MSBuildExtensionsPath)\Microsoft\MicrosoftAjax\ajaxmin.tasks" /> < Target Name ="AfterBuild" > < ItemGroup > < JS Include ="**\*.js" Exclude ="**\*.min.js;Scripts\*.js" /> </ ItemGroup > < ItemGroup > < CSS Include ="**\*.css" Exclude ="**\*.min.css" /> </ ItemGroup > < AjaxMin JsSourceFiles ="@(JS)" JsSourceExtensionPattern ="\.js$" JsTargetExtension =".min.js" CssSourceFiles ="@(CSS)" CssSourceExtensionPattern ="\.css$" CssTargetExtension =".min.css" /> </ Target > * This source code was highlighted with Source Code Highlighter .
    9. < Import Project ="$(MSBuildExtensionsPath)\Microsoft\MicrosoftAjax\ajaxmin.tasks" /> < Target Name ="AfterBuild" > < ItemGroup > < JS Include ="**\*.js" Exclude ="**\*.min.js;Scripts\*.js" /> </ ItemGroup > < ItemGroup > < CSS Include ="**\*.css" Exclude ="**\*.min.css" /> </ ItemGroup > < AjaxMin JsSourceFiles ="@(JS)" JsSourceExtensionPattern ="\.js$" JsTargetExtension =".min.js" CssSourceFiles ="@(CSS)" CssSourceExtensionPattern ="\.css$" CssTargetExtension =".min.css" /> </ Target > * This source code was highlighted with Source Code Highlighter .
    10. < Import Project ="$(MSBuildExtensionsPath)\Microsoft\MicrosoftAjax\ajaxmin.tasks" /> < Target Name ="AfterBuild" > < ItemGroup > < JS Include ="**\*.js" Exclude ="**\*.min.js;Scripts\*.js" /> </ ItemGroup > < ItemGroup > < CSS Include ="**\*.css" Exclude ="**\*.min.css" /> </ ItemGroup > < AjaxMin JsSourceFiles ="@(JS)" JsSourceExtensionPattern ="\.js$" JsTargetExtension =".min.js" CssSourceFiles ="@(CSS)" CssSourceExtensionPattern ="\.css$" CssTargetExtension =".min.css" /> </ Target > * This source code was highlighted with Source Code Highlighter .
    11. < Import Project ="$(MSBuildExtensionsPath)\Microsoft\MicrosoftAjax\ajaxmin.tasks" /> < Target Name ="AfterBuild" > < ItemGroup > < JS Include ="**\*.js" Exclude ="**\*.min.js;Scripts\*.js" /> </ ItemGroup > < ItemGroup > < CSS Include ="**\*.css" Exclude ="**\*.min.css" /> </ ItemGroup > < AjaxMin JsSourceFiles ="@(JS)" JsSourceExtensionPattern ="\.js$" JsTargetExtension =".min.js" CssSourceFiles ="@(CSS)" CssSourceExtensionPattern ="\.css$" CssTargetExtension =".min.css" /> </ Target > * This source code was highlighted with Source Code Highlighter .
    12. < Import Project ="$(MSBuildExtensionsPath)\Microsoft\MicrosoftAjax\ajaxmin.tasks" /> < Target Name ="AfterBuild" > < ItemGroup > < JS Include ="**\*.js" Exclude ="**\*.min.js;Scripts\*.js" /> </ ItemGroup > < ItemGroup > < CSS Include ="**\*.css" Exclude ="**\*.min.css" /> </ ItemGroup > < AjaxMin JsSourceFiles ="@(JS)" JsSourceExtensionPattern ="\.js$" JsTargetExtension =".min.js" CssSourceFiles ="@(CSS)" CssSourceExtensionPattern ="\.css$" CssTargetExtension =".min.css" /> </ Target > * This source code was highlighted with Source Code Highlighter .
    < Import Project ="$(MSBuildExtensionsPath)\Microsoft\MicrosoftAjax\ajaxmin.tasks" /> < Target Name ="AfterBuild" > < ItemGroup > < JS Include ="**\*.js" Exclude ="**\*.min.js;Scripts\*.js" /> </ ItemGroup > < ItemGroup > < CSS Include ="**\*.css" Exclude ="**\*.min.css" /> </ ItemGroup > < AjaxMin JsSourceFiles ="@(JS)" JsSourceExtensionPattern ="\.js$" JsTargetExtension =".min.js" CssSourceFiles ="@(CSS)" CssSourceExtensionPattern ="\.css$" CssTargetExtension =".min.css" /> </ Target > * This source code was highlighted with Source Code Highlighter .

  4. このプロジェクトのコンテキストメニュー項目は[プロジェクトの再読み込み ]です。サイトをVisual Studioのフォールドに戻し、ビルド(または再構築)を行って正常性をテストできます。
  5. プロジェクトに含まれていないファイルをスタジオに表示することが重要です( プロジェクトメニュー、すべてのファイルを表示 )。
  6. また、プロジェクトのコンパイル後に[ 更新 ]をクリックすることも重要です。そうしないと、MSBuildタスクによって追加された最小化されたファイルがスタジオに表示されません。
  7. エラーがどこにも浸透していない場合、最小化されたファイルは、このプロジェクトに属していないとしてプロジェクトのファイル構造に表示されます。 プロジェクトを含めるかどうかはあなた次第です。 開発者のコ​​ンピューターからFTPにファイルをコピーするだけなので、生成されたファイルはプロジェクトに含まれません。


MSBuild言語に精通していない人のために、パラグラフ3の簡単な説明:
  1. Microsoft Ajax Minifierでインストールされた新しいタスクを有効にするには
    < Import Project ="$(MSBuildExtensionsPath)\Microsoft\MicrosoftAjax\ajaxmin.tasks" />

    * This source code was highlighted with Source Code Highlighter .

  2. プロジェクトのコンパイルが成功した後に開始されたタスクの発表
    < Target Name ="AfterBuild" >

    * This source code was highlighted with Source Code Highlighter .

  3. 変換したいファイルのグループを宣言します-それらを最小化します。 <JS>および<CSS>タグは、ファイルグループの名前です。 これらの名前はユーザーが決定します。<JS>または<JSFiles>、または<MinimizeThis>を記述することもできます。 この場合、プロジェクト内の.jsおよび.cssで終わるすべてのファイルを最小化します。ただし、.min.jsまたは.min.cssで終わるファイル、またはScriptsフォルダーにあるファイルは除きます。
    1. < ItemGroup >
    2. < JS Include = "** \ * 。Js " Exclude = "** \ *。Min.js; Scripts \ *。Js" />
    3. </ ItemGroup >
    4. < ItemGroup >
    5. < CSS Include = "** \ * 。Css" Exclude = "** \ *。Min.css" />
    6. </ ItemGroup >
    *このソースコードは、 ソースコードハイライターで強調表示されました。

  4. 最小化タスクを実行します。 最小化するJavaScriptおよびCSSファイルのグループは、前の行で示された名前(<JS>および<CSS>)で示されます。 最小化するファイルと新しくパックされるファイルの拡張子は、属性JsSourceExtensionPatternCssSourceExtensionPatternおよびJsTargetExtensionCssTargetExtensionでそれぞれ指定されます。
    < AjaxMin JsSourceFiles ="@(JS)" JsSourceExtensionPattern ="\.js$" JsTargetExtension =".min.js" CssSourceFiles ="@(CSS)" CssSourceExtensionPattern ="\.css$" CssTargetExtension =".min.css" />

    * This source code was highlighted with Source Code Highlighter .



タスクにはいくつかの追加パラメーターがあります。
  1. JsCollapseToLiteral= "true|false"

    * This source code was highlighted with Source Code Highlighter .

    new Object(){}にnew Array()[]に変換します。
  2. JsCombineDuplicateLiterals= "true|false"

    * This source code was highlighted with Source Code Highlighter .

    コード内の重複する文字列または数値をローカル変数に置き換えます。
  3. JsEvalTreatment= "MakeAllSafe|Ignore|MakeImmediateSafe"

    * This source code was highlighted with Source Code Highlighter .

    evalを使用するコードで関数およびローカル変数の名前を変更する手法を適用できるかどうかを示します。 evalのコードの性質が明確でない場合、または変更される可能性がある場合は、この設定を避ける必要があります。
  4. JsIndentSize= " number "

    * This source code was highlighted with Source Code Highlighter .

    JsOutputMode = "MultipleLines"の場合、ネストされた構造に勝るスペースの数を示します。
  5. JsInlineSafeStrings= "true|false"

    * This source code was highlighted with Source Code Highlighter .

  6. JsLocalRenaming= "CrunchAll|KeepAll|KeepLocalizationVars"

    * This source code was highlighted with Source Code Highlighter .

    ローカル変数と関数の名前を変更する方法の適用度。 JsLocalRenaming = "KeepLo​​calizationVars"の場合、 L_で始まる変数の名前は変更されません。
  7. JsMacSafariQuirks= "true|false"

    * This source code was highlighted with Source Code Highlighter .

    Safari for MacのJavaScriptエンジン要件のサポート。
  8. JsOutputMode= "SingleLine|MultipleLines"

    * This source code was highlighted with Source Code Highlighter .

    他のすべての最小化手法(たとえば、ローカル変数の名前の変更)が引き続き適用されますが、コードを最小化しながら、ある程度の可読性を維持できます。
  9. JsRemoveFunctionExpressionNames= "true|false"

    * This source code was highlighted with Source Code Highlighter .

  10. JsRemoveUnneededCode= "true|false"

    * This source code was highlighted with Source Code Highlighter .

    プログラム実行プロセスに関係のないコード到達不能コード )を削除します。
  11. JsStripDebugStatements= "true|false"

    * This source code was highlighted with Source Code Highlighter .

    デバッガー$ DebugDebugWeb.DebugまたはMsn.DebugWAssertを探します。
  12. CssColorNames= "Strict|Hex|Major"

    * This source code was highlighted with Source Code Highlighter .

    指定された名前が短い場合( CssColorNames = "Strict" )に、RGBコードの代わりに色の名前を置き換える可能性を示します。
  13. CssCommentMode= "None|All|Hacks"

    * This source code was highlighted with Source Code Highlighter .

    CSSコメントにより最小化する機能を示します。 たとえば、 CssCommentMode =“ Hacks”は 、条件付きでコメントされたCSSハックのみをコードに残します。
  14. CssExpandOutput= "true|false"

    * This source code was highlighted with Source Code Highlighter .

    コードが1行ではなく複数行で表示される場合、ある程度の可読性を維持しながら、コードを最小化できます。
  15. CssSeverity= " number "

    * This source code was highlighted with Source Code Highlighter .

    どのCSSの不正確さがエラーとして報告されるかを示します。
  16. CssTermSemicolons= "true|false"

    * This source code was highlighted with Source Code Highlighter .

    CSSルール後のセミコロンの配置を制御します。


Microsoft Ajax Minifierのタスクを使用しこのようなプロジェクトをコンパイルするには、コンパイルプロセスに関与するすべてのマシンにこのユーティリティをインストールする必要があることに注意してください。

参照:
  1. Microsoft Ajax Minifier Webサイト: http ://aspnet.codeplex.com/releases/view/40584
  2. Microsoft Ajax Minifierの使用方法の学習: http ://www.asp.net/ajaxlibrary/AjaxMinQuickStart.ashx
  3. Microsoft Ajax MinifierのMSBuildタスクのパラメーター: http ://www.asp.net/ajaxLibrary/AjaxMinTask.ashx


トピックの続きとして、構成に応じて、通常の最小化されたJavaScriptファイルと組み合わせて、次世代のMicrosoftクライアントライブラリであるMicrosoft Ajax Libraryの使用に関する記事を書きたいと思います。

Source: https://habr.com/ru/post/J86067/


All Articles