MEAN.JS-アプリのAngularコンポーネント

この章では、アプリケーションに角度コンポーネントを追加します。これはWebフロントエンドJavaScriptフレームワークであり、Model View Controller(MVC)パターンを使用して動的な単一ページアプリケーションを作成できます。MEAN.JSアーキテクチャの章では、AngularJSがクライアントリクエストを処理し、データベースから結果を取得する方法を説明しました。

AngularJSを知る

AngularJSは、HTMLをテンプレート言語として使用し、HTMLの構文を拡張して、アプリケーションコンポーネントを明確に表現するオープンソースのWebアプリケーションフレームワークです。AngularJSは、データバインディング、モデル、ビュー、コントローラー、サービスなどのいくつかの基本機能を提供します。AngularJSの詳細については、このリンクを参照してください。

ページにAngularを追加することで、ページをAngularアプリケーションにすることができます。ダウンロードするか、CDNバージョンで直接参照できる外部JavaScriptファイルを使用するだけで追加できます。

次のようにページに追加して、ファイルをダウンロードし、ローカルで参照したとします。

<script src="angular.min.js"></script>

ここで、このページがAngularアプリケーションであることをAngularに伝える必要があります。したがって、以下に示すように、属性ng-appを<html>または<body>タグに追加することでこれを行うことができます-

<html ng-app>
or
<body ng-app>

ng-appはページ上の任意の要素に追加できますが、Angularがページ内のどこでも機能できるように、多くの場合<html>または<body>タグに配置されます。

モジュールとしてのAngularアプリケーション

Angularアプリケーションを操作するには、モジュールを定義する必要があります。これは、アプリケーションに関連するコンポーネント、ディレクティブ、サービスなどをグループ化できる場所です。モジュール名は、HTMLのng-app属性によって参照されます。たとえば、Angularアプリケーションモジュール名をmyAppと言い、以下に示すように<html>タグで指定できます-

<html ng-app="myApp">

外部JavaScriptファイルで以下のステートメントを使用してアプリケーションの定義を作成できます-

angular.module('myApp', []); //The [] parameter specifies dependent modules in the module definition

コントローラーの定義

AngularJSアプリケーションは、アプリケーション内のデータの流れを制御するためにコントローラーに依存しています。コントローラは、ng-controllerディレクティブを使用して定義されます。

たとえば、ng-controllerディレクティブを使用して、使用するコントローラーの名前とともにコントローラーを本体にアタッチします。以下の行では、コントローラーの名前を「myController」として使用しています。

<body ng-controller="myController">

以下に示すように、コントローラー(myController)をAngularモジュール(myApp)に接続できます-

angular
.module('myApp')
.controller('myController', function() {
   // controller code here
});

読みやすさ、再利用性、テスト性のために、匿名関数ではなく名前付き関数を使用することをお勧めします。以下のコードでは、新しい名前付き関数「myController」を使用してコントローラーコードを保持しています-

var myController = function() {
   // controller code here
};
angular
.module('myApp')
.controller('myController', myController);

コントローラの詳細については、このリンクを参照してください。

スコープの定義

スコープは、コントローラーをビューに接続し、モデルデータを含む特別なJavaScriptオブジェクトです。コントローラでは、モデルデータは$ scopeオブジェクトを介してアクセスされます。コントローラ関数は、Angularによって作成された$ scopeパラメータを受け取り、モデルへの直接アクセスを提供します。

以下のコードスニペットは、コントローラー関数を更新して$ scopeパラメーターを受け取る方法を指定し、デフォルト値を設定します-

var myController = function($scope) {
   $scope.message = "Hello World...";
};

コントローラの詳細については、このリンクを参照してください。次の章では、Angularを使用してシングルページアプリケーションの作成を開始します。