ウェブサイト開発ではモジュール構造が主流になりました。
ウェブサイトを作る主なタスクは、もはや自分でさまざまな機能を書くことではなく、さまざまなモジュールをどのように組み合わせるかです。
ブラウザ自体はモジュール管理メカニズムを提供していないため、各モジュールを呼び出すために、Web ページに大量のスクリプト タグを追加する必要がある場合があります。これにより、Web ページが肥大化して保守が困難になり、大量の HTTP リクエストが生成されるため、表示速度が低下し、ユーザー エクスペリエンスに影響を与えます。
この問題を解決するために、フロントエンドモジュールマネージャー(パッケージ管理)が登場しました。さまざまな JavaScript スクリプトの依存関係を簡単に管理し、各モジュールを自動的にロードして、Web ページの構造を明確かつ合理的にすることができます。今後、すべてのフロントエンド JavaScript プロジェクトはこの方法で開発されるべきであると言っても過言ではありません。
最も初期で最も有名なフロントエンド モジュール マネージャーは、他でもない RequireJS です。 AMD フォーマットを使用し、さまざまなモジュールを非同期的にロードします。具体的な使い方については、私が書いたチュートリアルを参照してください。 Require.js の問題は、さまざまなパラメーターの設定が煩雑で、学習が難しく、完全に習得するのが難しいことです。さらに、実際のアプリケーションでは、サーバー側ですべてのモジュールをマージし、均一にロードする必要があることが多く、これにより多くの作業負荷が追加されます。
今日は、他の 4 つのフロントエンド モジュール マネージャー、Bower、Browserify、Component、Duo を紹介します。それぞれに独特の特徴があり、Require.js の欠点をうまく補っており、フロントエンド開発にとって強力なツールです。
この記事はこれら 4 つのモジュール マネージャーのチュートリアルではないことに注意してください。読者が全体的な印象を持ち、特定の種類の作業を完了できる特定のツールがあることを知っていただけるように、最も簡単な例を使用してそれらの用途を説明したいと思います。詳しい使用方法については、それぞれのドキュメントを参照してください。
Bower の主な機能は、モジュールのインストール、アップグレード、削除のための統合された保守可能な管理モデルを提供することです。
まずはBowerをインストールします。
$ npm install -g bower
次に、bower install コマンドを使用して、さまざまなモジュールをインストールします。ここではいくつかの例を示します。
# 模块的名称 $ bower install jquery # github用户名/项目名 $ bower install jquery/jquery # git代码仓库地址 $ bower install git://github.com/user/package.git # 模块网址 $ bower install http://example.com/script.js
いわゆる「インストール」とは、モジュール (およびその依存モジュール) を現在のディレクトリの bower_components サブディレクトリにダウンロードすることを意味します。ダウンロードしたら、Web ページに直接挿入できます。
<script src="/bower_componets/jquery/dist/jquery.min.js">
モジュールの更新には Bower update コマンドを使用します。
$ bower update jquery
モジュール名が指定されていない場合は、すべてのモジュールが更新されます。
モジュールのアンインストールには Bower uninstall コマンドを使用します。
$ bower uninstall jquery
デフォルトでは依存モジュールも一緒にアンインストールされることに注意してください。たとえば、jquery-ui をアンインストールすると、jquery に依存する他のモジュールがない限り、jquery も一緒にアンインストールされます。
Browserify自体はモジュールマネージャーではなく、サーバーサイドのCommonJS形式モジュールをブラウザ側で実行できるようにするだけです。これは、これを通じて Node.js の npm モジュール マネージャーを使用できることを意味します。したがって、実際には、npm の機能を間接的にブラウザーに提供します。
まず、Browserifyをインストールします。
りぃそれではサーバーサイドスクリプトを書きます。
$ npm install -g browserify
上記コードのuniqモジュールはCommonJS形式なのでブラウザでは実行できません。この時点で、Browserify が登場し、上記のコードをブラウザ スクリプトにコンパイルします。
var uniq = require('uniq'); var nums = [ 5, 2, 1, 3, 2, 5, 4, 2, 0, 1 ]; console.log(uniq(nums));
生成されたbundle.jsはWebページに直接挿入できます。
$ browserify robot.js > bundle.js
Browserify がコンパイルされると、スクリプトが依存するモジュールも一緒にコンパイルされます。つまり、複数のモジュールを 1 つのファイルに結合できます。
コンポーネントは、Express フレームワークの作者である TJ Holowaychuk によって開発されたモジュール マネージャーです。その基本的な考え方は、Web ページに必要なさまざまなリソース (スクリプト、スタイル シート、画像、フォントなど) をコンパイルし、それらを同じディレクトリ (デフォルトはビルド ディレクトリ) に配置することです。
まずコンポーネントをインストールします。
<script src="bundle.js"></script>
上記のコードでコンポーネントのバージョンを指定する必要があるのは、バージョン 1.0 がまだ正式にリリースされていないためです。
次に、プロジェクトのルートディレクトリに新しいindex.htmlを作成します。
$ npm install -g component@1.0.0-rc5
上記コードのbuild.cssとbuild.jsがComponentで生成される対象ファイルです。
次に、プロジェクトのルートディレクトリにプロジェクト構成ファイルとして新しいcomponent.jsonファイルを作成します。
<!DOCTYPE html> <html> <head> <title>Getting Started with Component</title> <link rel="stylesheet" href="build/build.css"> </head> <body> <h1>Getting Started with Component</h1> <p class="blink">Woo!</p> <script src="build/build.js"></script> </body> </html>
上記のコードでは、JavaScriptスクリプトとスタイルシートを指定する元のファイルはindex.jsとindex.cssで、スタイルシートは正規化モジュールに依存しています(バージョン3.0.0以上、バージョン以下) 4.0)。ここで注意していただきたいのは、Componentモジュールの形式は「githubのユーザー名/プロジェクト名」ということです。
最後にコンポーネントビルドコマンドを実行してファイルをコンパイルします。
{ "name": "getting-started-with-component", "dependencies": { "necolas/normalize.css": "^3.0.0" }, "scripts": ["index.js"], "styles": ["index.css"] }
コンパイル中に、コンポーネントは自動的に autoprefixer を使用してブラウザーのプレフィックスを CSS プロパティに追加します。
現在、Component は半年近くコードリポジトリが変更されていない状態のようです。公式も次に紹介する Duo の使用を推奨しています。
Duo是在Component的基础上开发的,语法和配置文件基本通用,并且借鉴了Browserify和Go语言的一些特点,相当地强大和好用。
首先,安装Duo。
$ npm install -g duo
然后,编写一个本地文件index.js。
var uid = require('matthewmueller/uid'); var fmt = require('yields/fmt'); var msg = fmt('Your unique ID is %s!', uid()); window.alert(msg);
上面代码加载了uid和fmt两个模块,采用Component的"github用户名/项目名"格式。
接着,编译最终的脚本文件。
$ duo index.js > build.js
编译后的文件可以直接插入网页。
<script src="build.js"></script>
Duo不仅可以编译JavaScript,还可以编译CSS。
@import 'necolas/normalize.css'; @import './layout/layout.css'; body { color: teal; background: url('./background-image.jpg'); }
编译时,Duo自动将normalize.css和layout.css,与当前样式表合并成同一个文件。
$ duo index.css > build.css
编译后,插入网页即可。
<link rel="stylesheet" href="build.css">