SHOEISHA iD

※旧SEメンバーシップ会員の方は、同じ登録情報(メールアドレス&パスワード)でログインいただけます

CodeZine編集部では、現場で活躍するデベロッパーをスターにするためのカンファレンス「Developers Summit」や、エンジニアの生きざまをブーストするためのイベント「Developers Boost」など、さまざまなカンファレンスを企画・運営しています。

AngularJSではじめるJavaScriptフレームワーク開発スタイル

ビジネスロジック記述の必須知識、AngularJSの「サービス機能」を理解しよう

AngularJSで初めるJavaScriptフレームワーク開発スタイル 第4回


  • X ポスト
  • このエントリーをはてなブックマークに追加

 本連載は、JavaScriptのMVCフレームワークである、AngularJSを使った開発の解説記事です。今回は、AngularJSのサービス機能を使ってのデータ管理について説明します。

  • X ポスト
  • このエントリーをはてなブックマークに追加

はじめに

 前回に引き続き、図1のようなタスク管理をするサンプルを作成します。前回までで画面の作成とボタンのアクションのイベント等の処理が終了し、画面周りについては完成しました。

 しかし、まだ、実際のデータの登録、削除などを含めてデータの管理は行っていません。今回は、AngularJSのサービス機能を使ってタスクのデータ管理を扱う部分を実装します。

図1:作成するアプリケーションの概要
図1:作成するアプリケーションの概要

対象読者

  • jQueryなどを使っている開発者
  • JavaScriptを使った複数人でのプロジェクトに参加している方
  • JavaScriptを使ってサーバ等と連携したフロントエンドの開発をしている方

必要な環境

 この記事では、AngularJSを使用し、Chrome(39.0)、IE11、Firefox(34.0)、Safari(8.0.2)の環境にて確認を行っています。

サービスとは

 AngularJSでのサービスは大きく分けて2つの目的で使用されます。ひとつは今回のサンプルで作成するようにビジネスロジックを記述するため、もうひとつはユーティリティ等の汎用機能として使われます。例えば、ログの記述や、Ajaxのための機能は既にAngularJSで用意されていますが、こちらもサービス機能を使って実装されています。一般的にこれらを、MVC構造では「モデル」と呼んでいます。前回までに利用してきたディレクティブやコントローラと今回紹介するサービスを、MVC構造で記述すると図2のようになります。

図2:AngularJSのMVC構造
図2:AngularJSのMVC構造

 また、各サービスのインスタンスはアプリケーションで1つ、という大きな特徴を持っています。少々難しい言い方をすれば、シングルトンのオブジェクトという扱いになります。この特徴を利用して、各コントローラ間などでデータ共有をすることもできます。今回サンプルとして作成するItemsサービスは図3のような関係になり、各コントローラからDI機能を使って利用されます。

図3:カスタムサービスとその他コンポーネント
図3:カスタムサービスとその他コンポーネント

次のページ
サービスの登録方法

この記事は参考になりましたか?

  • X ポスト
  • このエントリーをはてなブックマークに追加
AngularJSではじめるJavaScriptフレームワーク開発スタイル連載記事一覧

もっと読む

この記事の著者

山田 祥寛(ヤマダ ヨシヒロ)

静岡県榛原町生まれ。一橋大学経済学部卒業後、NECにてシステム企画業務に携わるが、2003年4月に念願かなってフリーライターに転身。Microsoft MVP for Visual Studio and Development Technologies。執筆コミュニティ「WINGSプロジェクト」代表。主な著書に「独習シリーズ(Java・C#・Python・PHP・Ruby・JSP&サーブレットなど)」「速習シリーズ(ASP.NET Core・Vue.js・React・TypeScript・ECMAScript、Laravelなど)」「改訂3版JavaScript本格入門」「これからはじめるReact実践入門」「はじめてのAndroidアプリ開発 Kotlin編 」他、著書多数

※プロフィールは、執筆時点、または直近の記事の寄稿時点での内容です

WINGSプロジェクト 小林 昌弘(コバヤシ マサヒロ)

WINGSプロジェクトについて>有限会社 WINGSプロジェクトが運営する、テクニカル執筆コミュニティ(代表 山田祥寛...

※プロフィールは、執筆時点、または直近の記事の寄稿時点での内容です

この記事は参考になりましたか?

この記事をシェア

  • X ポスト
  • このエントリーをはてなブックマークに追加
CodeZine(コードジン)
https://codezine.jp/article/detail/8377 2015/01/23 19:06

おすすめ

アクセスランキング

アクセスランキング

イベント

CodeZine編集部では、現場で活躍するデベロッパーをスターにするためのカンファレンス「Developers Summit」や、エンジニアの生きざまをブーストするためのイベント「Developers Boost」など、さまざまなカンファレンスを企画・運営しています。

新規会員登録無料のご案内

  • ・全ての過去記事が閲覧できます
  • ・会員限定メルマガを受信できます

メールバックナンバー

アクセスランキング

アクセスランキング