なお、本連載ではAngularJSそのものに関しては解説しませんので、専門書として『AngularJSアプリケーションプログラミング』、姉妹連載「AngularJSではじめるJavaScriptフレームワーク開発スタイル」などを合わせて参照してください。
はじめに
前回はUI BootstrapのDatepicker/Timepickerディレクティブを利用して、日付/時刻入力ボックスを実装しました。
今回も引き続き、日付の話題。日付に紐づいた情報をカレンダー上に表示してみます。利用するのは、以下のライブラリです。
- UI Bootstrap(Datepicker)
- UI Calendar
対象読者
- AngularJSについて基本的な概念を理解している方
- AngularJSで利用できる拡張モジュールに興味がある方
- AngularJSアプリ上でカレンダーにアプリ固有の情報を埋め込みたい方
検証環境
この記事では、以下の環境でサンプルの動作を確認しています。
- AngularJS 1.5.2
- UI Bootstrap 1.2.5
- UI Calendar 1.0.1
- Chrome 49
- Firefox 45
- Internet Explorer 11
簡易なカレンダーを表示する - UI Bootstrap(Datepicker)
前回紹介したUI Bootstrap(Datepicker)の続きです。UI Bootstrap(Datepicker)で生成できるのは、ポップアップカレンダーだけではありません。ページに直接埋め込める、いわゆるインラインカレンダーを実装する際にも利用できます。
これには、以下のように<datepicker>要素を利用してください。
<!DOCTYPE html>
<html ng-app="myApp">
<head>
<meta charset="UTF-8" />
<title>AngularJS</title>
<link rel="stylesheet" href="bower_components/bootstrap/dist/css/bootstrap.min.css" />
<script src="bower_components/angular/angular.min.js"></script>
<script src="bower_components/angular-i18n/angular-locale_ja-jp.js"></script>
<script src="bower_components/angular-bootstrap/ui-bootstrap-tpls.min.js"></script>
<script src="scripts/calendar.js"></script>
</head>
<body ng-controller="MyController">
<!-- (1)ng-model属性に変数currentを紐づけ -->
<uib-datepicker ng-model="current" datepicker-options="options">
</uib-datepicker>
{{current.toLocaleString()}}
</body>
</html>
angular.module('myApp', [ 'ui.bootstrap' ])
.controller('MyController', ['$scope', function($scope) {
$scope.options = {
formatDayTitle: "yyyy年MM月",
// (2)minDateに今日の日付を設定
minDate: new Date(),
showWeeks: true
};
}]);
<datepicker>要素で利用できる、主な属性は以下の通りです。
| 属性 | 概要 | デフォルト値 |
|---|---|---|
| ng-model | 日付値を格納するモデル | - |
| datepicker-options | カレンダーに適用するオプション | (設定値は前回の表を参照) |
(1)では、ng-model属性に変数currentを紐づけていますので、カレンダーで選択された日付を文字列変換した上でページに反映させなさいという意味になります。ただし、ここではminDateオプションに今日の日付をセットしていますので、カレンダー上は、今日以前の日付は選択できません(2)。
