SlideShare a Scribd company logo
Angular2実践入門
株式会社オープンウェブ・テクノロジー
白石俊平
自己紹介
• html5jファウンダー
• HTML5 Experts.jp編集長
• 株式会社オープンウェブ・テクノロ
ジー代表取締役
• TechFeedというサービスをはじめ
ました
本日の流れ
• ライブコーディングで学ぶAngular2
• Angular2を始めたらあなたが出会うであ
ろう11のこと
ライブコーディングで学ぶ
Angular2
スターターキット作りました
• https://goo.gl/WiM2zn
– 短縮前: https://github.com/shumpei/angular2-webpack-starter-minimum
• Angular2をWebpackで始めるための最小構成。
– 教育用途、もしくは開発環境を自作したい人向け
• Out-of-boxを求めるなら以下がおすすめ
– angular-seed・・・公式のスターターキット。全
部入り。
– angular-webpack-starter・・・それなりにコンパ
クトで割と全部入り
動かしてみる
$ git clone https://github.com/shumpei/angular2-
webpack-starter-minimum
$ cd angular2-webpack-starter-minimum
$ npm install
$ npm start
http://localhost:8080/webpack-dev-server/
Angular2の特徴
• TypeScriptを推奨
• コンポーネント指向
• ちょっとキモい
• Angularっぽさ
• やっぱりキモい
特徴その1: TypeScript
• ES.next全部 + 型
• 実験的なサポート扱いの「デコレー
ター」は必須
コードを眺めてみる
import {Component} from 'angular2/core';
@Component({
selector: 'my-app',
templateUrl: '/src/components/app.component.html'
})
export class AppComponent {
}
app.component.ts
import {Component} from 'angular2/core';
@Component({
selector: 'my-app',
templateUrl: '/src/components/app.component.html'
})
export class AppComponent {
}
コンポーネント定義
(デコレーター)
app.component.ts
import {Component} from 'angular2/core';
@Component({
selector: 'my-app',
templateUrl: '/src/components/app.component.html'
})
export class AppComponent {
}
<my-app>で
埋め込めるように
app.component.ts
import {Component} from 'angular2/core';
@Component({
selector: 'my-app',
templateUrl: '/src/components/app.component.html'
})
export class AppComponent {
}
テンプレート
ファイルのURL
app.component.ts
特徴その2: コンポーネント指向
• UIコンポーネントをツリー上に構成して
アプリケーションを作る
コンポーネントを書いてみる
import {Component} from 'angular2/core';
@Component({
selector: 'my-alert-button',
templateUrl: '/src/components/alert-
button.component.html'
})
export class AlertButtonComponent {
}
alert-button.component.ts
<button>Click me!</button>
alert-button.component.html
<my-alert-button>で
埋め込めるように
import {Component} from 'angular2/core';
@Component({
selector: 'my-app',
templateUrl: '/src/components/app.component.html',
directives: [AlertButtonComponent]
})
export class AppComponent {
}
使用するディレク
ティブを宣言
app.component.ts
<h1>My first Angular2 app!</h1>
<my-alert-button></my-alert-button>
alert-button.component.html
ディレクティブを
利用
特徴その3: ちょっとキモい
• テンプレートのシンタックスがキモい
クリックイベントを捕捉してみる
<button (click)="onClick()">Click me!</button>
キモい
alert-button.component.ts
export class AlertButtonComponent {
onClick(): void {
window.alert('Hello!');
}
}
alert-button.component.ts
対応するイベントハ
ンドラ
特徴その4: Angularっぽさ
• サービス/DI/ディレクティブなど、
Angular1で使われてた用語/概念を引き
継いでいる
– やり方は大きく変わったけど
サービスを書いてDIしてみる
import {Injectable} from 'angular2/core';
@Injectable()
export class MyService {
loadData(): string[] {
return ['a', 'b', 'c'];
}
}
DI可能なサービスの
定義
my.service.ts
...
import {MyService} from '../services/my.service';
@Component({
selector: 'my-app',
templateUrl: '/src/components/app.component.html',
directives: [AlertButtonComponent],
providers: [MyService]
})
export class AppComponent {
private data: string[];
constructor(private myService: MyService) {
this.data = myService.loadData();
}
}
プロバイダの指定
my.service.ts
Inject!
特徴その5: やっぱりキモい
• テンプレート中では、以下の様な記法を
要素内に記述していくことになる。
– ( ), [ ], [( )], #, *
– 全力出すとこんな感じ:
• HTML/CSSをデコレーターで指定できる
<input *ngIf="alive" [(ngModel)]="name" #name>
ループを書いてみる(ngFor)
...
<ul>
<li *ngFor="#item of data">{{item}}</li>
</ul>
DI可能なサービスの
定義
app.component.html
テンプレートをデコレーターに
埋め込んでみる。
ついでにCSSも。
@Component({
selector: 'my-app',
template: `
<h1>My first Angular2 app!</h1>
<my-alert-button></my-alert-button>
<ul>
<li *ngFor="#item of data">{{item}}</li>
</ul>
`,
styles: [`
h1 {
color: red;
}
`],
directives: [AlertButtonComponent],
providers: [MyService]
})
export class AppComponent {...}
alert-button.component.ts
app.component.ts
HTMLもCSSも
デコレータに埋め込
める
CSSもカプセル化される
• @Componentデコレーターのstylesというプ
ロパティにCSSを指定できる。
• そのCSSはコンポーネント内のみ有効
import {Component} from 'angular2/core';
@Component({
selector: 'my-alert-button',
templateUrl: '/src/components/alert-
button.component.html',
styles: [`* {color: blue;}`]
})
export class AlertButtonComponent {
}
コンポーネント外に
は影響しない
Angular2を始めたらあなたが
出会うであろう11のこと
techfeed.io
最先端が、ここにある。
世界中からエンジニア向け情報を収集するサービス
Angular2を仕事で使ってみた
その1: ハードル高くない?
• 前提技術大杉。
– TypeScript (ES.next全部+型)
– モジュールバンドラー
– RxJS
– そしてもちろんAngular2
• 意外とそうでもなかった(個人的には)
– Angularの文脈を引き継いでいる
– TypeScriptはJavaっぽい(白石は元Java屋)
– RxJSは最初から詳しく知っている必要なし
– Webpackの調整が一番時間かかった。。
• でもこれは誰か一人がやればいいこと
その2: 言語はどれを選ぶ?
• TypeScript一択、だと思う
– ドキュメント完備
– 型があるのは嬉しい(コンパイル/コード補
完)
– デコレーターが嬉しい
• その他の選択肢について
– JavaScript/Babel…止めはしない。
(が、きっとTSのほうが楽)
– Dart…ごめんなさい
その3: バンドラーを何にする?
• TypeScriptを選んだのなら、モジュールバ
ンドラー必須
import {Component} from 'angular2/core'
↓ (TypeScriptコンパイラ)
var Component = require('angular2/core').Component;
↓ (モジュールバンドラーがrequireをブラウザ上で使えるよう変換)
var component_1 = __webpack_require__(1);
その3: バンドラーを何にする?
• TechFeedではWebpackを選択
– 実績豊富
– なんでもできそう
– 既に下調べが済んでいた
• その他の選択肢について
– Browserify…未調査
– System.js
• 現在のところAngular2公式?
• 後発なため情報が少なめ
• JSPMも組み合わせる必要あり?
• 参考文献
– http://webpack.github.io/docs/comparison.html
– http://ilikekillnerds.com/2015/07/jspm-vs-webpack/
その4: エディタは何にする?
• TypeScript対応のものを(できればtslint
も)
– Atom+Plugins
– Sublime Text+Plugins
– Visual Studio Code
– WebStorm
• 元Java屋さんとしては、「IDE」にも心惹
かれる今日このごろ
その5: テンプレートを
どこに書く?
Webpackを使えばこんなことも!
@Component({template: `code`}) // (1)
@Component({templateUrl:'url'}) // (2)
VS
@Component({template:require('a.html')}) // (3)
リクエスト数 ファイル数 HTML分離 エディタサ
ポート
前処理
(1)埋め込み 少 少 × × ×
(2)URL 多 多 ○ ○ ×
(3)Webpack 少 少 ○ ○ ○
その6: テンプレートがキモい
• 慣れろ
• 新しいメンタルモデルを理解すれば、少しは楽に
なる。
– こいつはHTMLじゃない。HTML Plusだ。
– タグの属性と(DOMの)プロパティはそもそも似て非
なるものだ。
– [ ]はプロパティを指している
– 属性ってやつは、プロパティの初期化に過ぎない。
<!-- 属性でスタイルを指定 -->
<div style="font-size: 16px"></div>
<!-- プロパティでスタイルを指定 -->
<div [style.fontSize]="16px"></div>
その7: Sassを使いたい
• モジュールバンドラーの機能を駆使すれば、
Sass/Less/Stylus/PostCSSなども利用可能
@Component({styles:[require('comp.scss')]})
loaders: [
{test: /.scss$/,
loaders: ['raw', 'sass?sourceMap', 'postcss'],
exclude: /node_modules/}
...
]
• Webpackでの設定例
その8: RxJSとのつきあい方
• RxJS(リアクティブプログラミング用ライブラリ)
は、理解が必須ではないものの、限りなく必須に近い
– HTTP, EventEmitterなどの頻出APIがRxJS前提なため
• ObservableはES7にも提案されているので、この機会
に勉強しておくのは吉
– でも、奥深すぎ。。
• Angular2はRxJS5 (Beta)を使っているので要注意!
– ググッて先頭に出てくるのは4系
– 「ReactiveX」ってやつが5系です
– 5系は、ドキュメントとかもまだまだ・・・
その9: ページネーションしたい
• よくあるユースケースだけど、世界中が現在実装方法
を模索中
• ぼくらはObservableの簡単なラッパーを作りました
– 以下はイメージを伝えるための擬似コード
interface PagedObservable<T> extends Observable<T> {
nextPage(): void;
}
class EntryService {
getTimeline(): PagedObservable<Entry[]>
}
class TimelineComponent {
timeline: PagedObservable<Entry[]>;
more() { this.timeline.nextPage(); }
}
その10: UIフレームワーク
使いたい!
• TechFeedではIonic2を採用
– Angular2で完全にリライトされている
– Angular2開発の参考にもなる
• その他(調査中)
– Onsen UI 2.0
– angular-material2
– ng2-bootstrap
その11: コンポーネント設計
• コンポーネントの粒度や、振る舞いや状態をどこ
に配置するかは、現在熱い話題
• 「Presentational and Container Components」が
議論の土台
– だが、やはり悩ましい
– 「全部外側に移譲する」ってこと?めんどくさすぎ
ない?
– Google MapsやYoutubeの埋め込みプレーヤー、「い
いね!」ボタンなどは良いコンポーネントの例に思
える。スマートだけど再利用性高い。
• 「必要になるまで分割するな」
– 個人的に、唯一の正解と思えていること
おまけ
Angularの最新情報は
こちらでどうぞ!
https://techfeed.io/channels/AngularJS
ご清聴ありがとうございました。

More Related Content

PDF
Concourseで快適な自動化の旅
PPTX
モデルアーキテクチャ観点からの高速化2019
PDF
コンピュータビジョンで作る未来の栽培技術POL共催セミナー_20220527
PDF
[DL輪読会]Adversarial Learning for Zero-shot Domain Adaptation
PDF
コンピューテーショナルフォトグラフィ
PDF
楽しいShaderToy
PPTX
[DL輪読会]DropBlock: A regularization method for convolutional networks
PDF
【DL輪読会】Deep Transformers without Shortcuts: Modifying Self-attention for Fait...
Concourseで快適な自動化の旅
モデルアーキテクチャ観点からの高速化2019
コンピュータビジョンで作る未来の栽培技術POL共催セミナー_20220527
[DL輪読会]Adversarial Learning for Zero-shot Domain Adaptation
コンピューテーショナルフォトグラフィ
楽しいShaderToy
[DL輪読会]DropBlock: A regularization method for convolutional networks
【DL輪読会】Deep Transformers without Shortcuts: Modifying Self-attention for Fait...

What's hot (20)

PDF
機械学習応用システムの安全性の研究動向と今後の展望
PPTX
[DL輪読会]ドメイン転移と不変表現に関するサーベイ
PPTX
【DL輪読会】Representational Continuity for Unsupervised Continual Learning ( ICLR...
PDF
Riderはいいぞ!
PDF
【論文読み会】Deep Clustering for Unsupervised Learning of Visual Features
PPTX
アンリアルエンジン4で ノンフォトリアル描画しよう!@UNREAL FEST 2015 YOKOHAMA
PDF
CuPy解説
PDF
協働ロボットCOROの開発における形式的仕様記述KMLの開発と適用
PDF
Hair Groom入門 (UE4 Character Art Dive Online)
PDF
[DL輪読会]Neuroscience-Inspired Artificial Intelligence
PDF
アップルの特許に見るUI特許のポイント
PPTX
MLOpsはバズワード
PPTX
Semi supervised, weakly-supervised, unsupervised, and active learning
PPTX
【DL輪読会】Llama 2: Open Foundation and Fine-Tuned Chat Models
PDF
点群を使いこなせ! 可視化なんて当たり前、xRと点群を組み合わせたUnityの世界 【Interact , Stipple】
PDF
Unity dojo amplifyshadereditor101_jpn-jp
PDF
GUILTY GEAR Xrd開発スタッフが送るアニメ調キャラモデリングTIPS
PDF
ディープラーニングのフレームワークと特許戦争
PDF
第1回 【初心者向け】Unity+Oculus Riftで次世代の3Dゲームを作って感じるワークショップ
PPTX
Jupyterカーネルを魔改造した話
機械学習応用システムの安全性の研究動向と今後の展望
[DL輪読会]ドメイン転移と不変表現に関するサーベイ
【DL輪読会】Representational Continuity for Unsupervised Continual Learning ( ICLR...
Riderはいいぞ!
【論文読み会】Deep Clustering for Unsupervised Learning of Visual Features
アンリアルエンジン4で ノンフォトリアル描画しよう!@UNREAL FEST 2015 YOKOHAMA
CuPy解説
協働ロボットCOROの開発における形式的仕様記述KMLの開発と適用
Hair Groom入門 (UE4 Character Art Dive Online)
[DL輪読会]Neuroscience-Inspired Artificial Intelligence
アップルの特許に見るUI特許のポイント
MLOpsはバズワード
Semi supervised, weakly-supervised, unsupervised, and active learning
【DL輪読会】Llama 2: Open Foundation and Fine-Tuned Chat Models
点群を使いこなせ! 可視化なんて当たり前、xRと点群を組み合わせたUnityの世界 【Interact , Stipple】
Unity dojo amplifyshadereditor101_jpn-jp
GUILTY GEAR Xrd開発スタッフが送るアニメ調キャラモデリングTIPS
ディープラーニングのフレームワークと特許戦争
第1回 【初心者向け】Unity+Oculus Riftで次世代の3Dゲームを作って感じるワークショップ
Jupyterカーネルを魔改造した話

Similar to Angular2実践入門 (16)

PDF
はじめてのAngular その1
PPTX
僕はどうしてAngular2をテーマに登壇することになってしまったのか
PDF
今からでも遅くない! 2から始めるangular js
PDF
イベント駆動AngularJS / 今から書くAngular 2.0
PDF
pairsでのAngularJS x TypeScript x e2e @めぐすた#1
PDF
traceur-compilerで未来のJavaScriptを体験
PPTX
エンタープライズ分野での実践AngularJS
PDF
Angular2
PDF
angular1脳で見るangular2
PDF
Ecmascript2015とその周辺について
PPTX
Our Track to Modern Angular
PPTX
angularJS vs angular2
PPTX
TypeScriptからひも解く方向性
PDF
Buildinsider OFFLINE TypeScriptの基礎から実践・利用事例まで
PDF
TypeScript 言語処理系ことはじめ
はじめてのAngular その1
僕はどうしてAngular2をテーマに登壇することになってしまったのか
今からでも遅くない! 2から始めるangular js
イベント駆動AngularJS / 今から書くAngular 2.0
pairsでのAngularJS x TypeScript x e2e @めぐすた#1
traceur-compilerで未来のJavaScriptを体験
エンタープライズ分野での実践AngularJS
Angular2
angular1脳で見るangular2
Ecmascript2015とその周辺について
Our Track to Modern Angular
angularJS vs angular2
TypeScriptからひも解く方向性
Buildinsider OFFLINE TypeScriptの基礎から実践・利用事例まで
TypeScript 言語処理系ことはじめ

More from Shumpei Shiraishi (20)

PDF
俺的GEB概論(前半)
PPTX
コンセプトのつくりかた - アイデアをかたちにする技術
PPTX
jQueryの先に行こう!最先端のWeb開発トレンドを学ぶ
PPTX
TechFeedのつくりかた - Angular2/Webpack/Ionic2/Cordova実践入門
PPTX
JavaScript使いのためのTypeScript実践入門
PPTX
「それでも人生にイエスと言う」を読んで
PPTX
「それでも人生にイエスと言う」を読んで
PDF
WebRTCがビデオ会議市場に与えるインパクトを探る
PDF
変身×フランツ・カフカ
PPTX
イラスト日用服飾辞典/三面記事の歴史/健康男 を読んで
PPTX
「1秒でわかる!アパレル業界ハンドブック」を読んで
PPTX
漫☆画太郎論
PPTX
HTML5時代のフロントエンド開発入門
PPTX
6,000人のWeb技術者コミュニティを5年間やってみて学んだこと
PPTX
はじめにことばありき
PPTX
秒速一億円
PPTX
HTML5がもたらすアプリ開発へのインパクト
PPTX
この人と結婚していいの?を読んで
PPT
20130921レジュメ2
PPTX
第62回 読書するエンジニアの会(テーマ:メカ) 「Prototyping lab」
俺的GEB概論(前半)
コンセプトのつくりかた - アイデアをかたちにする技術
jQueryの先に行こう!最先端のWeb開発トレンドを学ぶ
TechFeedのつくりかた - Angular2/Webpack/Ionic2/Cordova実践入門
JavaScript使いのためのTypeScript実践入門
「それでも人生にイエスと言う」を読んで
「それでも人生にイエスと言う」を読んで
WebRTCがビデオ会議市場に与えるインパクトを探る
変身×フランツ・カフカ
イラスト日用服飾辞典/三面記事の歴史/健康男 を読んで
「1秒でわかる!アパレル業界ハンドブック」を読んで
漫☆画太郎論
HTML5時代のフロントエンド開発入門
6,000人のWeb技術者コミュニティを5年間やってみて学んだこと
はじめにことばありき
秒速一億円
HTML5がもたらすアプリ開発へのインパクト
この人と結婚していいの?を読んで
20130921レジュメ2
第62回 読書するエンジニアの会(テーマ:メカ) 「Prototyping lab」

Angular2実践入門