OnsenUI + AngularJS + CloudEndpointsで作るSPA 地雷処理の巻
-
Upload
hiroshi-furuyama -
Category
Engineering
-
view
588 -
download
2
Transcript of OnsenUI + AngularJS + CloudEndpointsで作るSPA 地雷処理の巻
![Page 1: OnsenUI + AngularJS + CloudEndpointsで作るSPA 地雷処理の巻](https://reader036.fdocument.pub/reader036/viewer/2022081511/5871b08e1a28abda6a8b6825/html5/thumbnails/1.jpg)
OnsenUI + AngularJS + CloudEndpoints
( 株 ) ISAO古山 浩志
で作るSPA 地雷処理の巻
![Page 2: OnsenUI + AngularJS + CloudEndpointsで作るSPA 地雷処理の巻](https://reader036.fdocument.pub/reader036/viewer/2022081511/5871b08e1a28abda6a8b6825/html5/thumbnails/2.jpg)
#ISAOcorp
自己紹介
![Page 3: OnsenUI + AngularJS + CloudEndpointsで作るSPA 地雷処理の巻](https://reader036.fdocument.pub/reader036/viewer/2022081511/5871b08e1a28abda6a8b6825/html5/thumbnails/3.jpg)
#ISAOcorp
自転車乗り
![Page 4: OnsenUI + AngularJS + CloudEndpointsで作るSPA 地雷処理の巻](https://reader036.fdocument.pub/reader036/viewer/2022081511/5871b08e1a28abda6a8b6825/html5/thumbnails/4.jpg)
![Page 5: OnsenUI + AngularJS + CloudEndpointsで作るSPA 地雷処理の巻](https://reader036.fdocument.pub/reader036/viewer/2022081511/5871b08e1a28abda6a8b6825/html5/thumbnails/5.jpg)
#ISAOcorp
4 児の父
![Page 6: OnsenUI + AngularJS + CloudEndpointsで作るSPA 地雷処理の巻](https://reader036.fdocument.pub/reader036/viewer/2022081511/5871b08e1a28abda6a8b6825/html5/thumbnails/6.jpg)
![Page 7: OnsenUI + AngularJS + CloudEndpointsで作るSPA 地雷処理の巻](https://reader036.fdocument.pub/reader036/viewer/2022081511/5871b08e1a28abda6a8b6825/html5/thumbnails/7.jpg)
#ISAOcorp
定時帰りhttp://qiita.com/furu8ma/items/f909b8820c9d6d21897a
![Page 8: OnsenUI + AngularJS + CloudEndpointsで作るSPA 地雷処理の巻](https://reader036.fdocument.pub/reader036/viewer/2022081511/5871b08e1a28abda6a8b6825/html5/thumbnails/8.jpg)
#ISAOcorp
![Page 9: OnsenUI + AngularJS + CloudEndpointsで作るSPA 地雷処理の巻](https://reader036.fdocument.pub/reader036/viewer/2022081511/5871b08e1a28abda6a8b6825/html5/thumbnails/9.jpg)
#ISAOcorp
プログラマー
![Page 10: OnsenUI + AngularJS + CloudEndpointsで作るSPA 地雷処理の巻](https://reader036.fdocument.pub/reader036/viewer/2022081511/5871b08e1a28abda6a8b6825/html5/thumbnails/10.jpg)
![Page 11: OnsenUI + AngularJS + CloudEndpointsで作るSPA 地雷処理の巻](https://reader036.fdocument.pub/reader036/viewer/2022081511/5871b08e1a28abda6a8b6825/html5/thumbnails/11.jpg)
GO って検索しずらすぎる
![Page 12: OnsenUI + AngularJS + CloudEndpointsで作るSPA 地雷処理の巻](https://reader036.fdocument.pub/reader036/viewer/2022081511/5871b08e1a28abda6a8b6825/html5/thumbnails/12.jpg)
![Page 13: OnsenUI + AngularJS + CloudEndpointsで作るSPA 地雷処理の巻](https://reader036.fdocument.pub/reader036/viewer/2022081511/5871b08e1a28abda6a8b6825/html5/thumbnails/13.jpg)
#ISAOcorp
まとめると
![Page 14: OnsenUI + AngularJS + CloudEndpointsで作るSPA 地雷処理の巻](https://reader036.fdocument.pub/reader036/viewer/2022081511/5871b08e1a28abda6a8b6825/html5/thumbnails/14.jpg)
#ISAOcorp
自転車乗りで4 児の父で定時帰りなプログラマー
![Page 15: OnsenUI + AngularJS + CloudEndpointsで作るSPA 地雷処理の巻](https://reader036.fdocument.pub/reader036/viewer/2022081511/5871b08e1a28abda6a8b6825/html5/thumbnails/15.jpg)
#ISAOcorp
そんな社員でも受け止めてくれる
( 株 )ISAO
![Page 16: OnsenUI + AngularJS + CloudEndpointsで作るSPA 地雷処理の巻](https://reader036.fdocument.pub/reader036/viewer/2022081511/5871b08e1a28abda6a8b6825/html5/thumbnails/16.jpg)
#ISAOcorp
いい会社ですhttps://www.isao.co.jp/
![Page 17: OnsenUI + AngularJS + CloudEndpointsで作るSPA 地雷処理の巻](https://reader036.fdocument.pub/reader036/viewer/2022081511/5871b08e1a28abda6a8b6825/html5/thumbnails/17.jpg)
OnsenUI + AngularJS + CloudEndpoints
で作るSPA 地雷処理の巻
![Page 18: OnsenUI + AngularJS + CloudEndpointsで作るSPA 地雷処理の巻](https://reader036.fdocument.pub/reader036/viewer/2022081511/5871b08e1a28abda6a8b6825/html5/thumbnails/18.jpg)
#ISAOcorp
• 背景作ったもの踏んだ地雷フィードバック
![Page 19: OnsenUI + AngularJS + CloudEndpointsで作るSPA 地雷処理の巻](https://reader036.fdocument.pub/reader036/viewer/2022081511/5871b08e1a28abda6a8b6825/html5/thumbnails/19.jpg)
#ISAOcorp
• 背景作ったもの踏んだ地雷フィードバック
![Page 20: OnsenUI + AngularJS + CloudEndpointsで作るSPA 地雷処理の巻](https://reader036.fdocument.pub/reader036/viewer/2022081511/5871b08e1a28abda6a8b6825/html5/thumbnails/20.jpg)
#ISAOcorp
WHY SPA
![Page 21: OnsenUI + AngularJS + CloudEndpointsで作るSPA 地雷処理の巻](https://reader036.fdocument.pub/reader036/viewer/2022081511/5871b08e1a28abda6a8b6825/html5/thumbnails/21.jpg)
#ISAOcorp
全部対応して
![Page 22: OnsenUI + AngularJS + CloudEndpointsで作るSPA 地雷処理の巻](https://reader036.fdocument.pub/reader036/viewer/2022081511/5871b08e1a28abda6a8b6825/html5/thumbnails/22.jpg)
#ISAOcorp
iOS + Android + PC別々に組む
![Page 23: OnsenUI + AngularJS + CloudEndpointsで作るSPA 地雷処理の巻](https://reader036.fdocument.pub/reader036/viewer/2022081511/5871b08e1a28abda6a8b6825/html5/thumbnails/23.jpg)
メンテつらい
![Page 24: OnsenUI + AngularJS + CloudEndpointsで作るSPA 地雷処理の巻](https://reader036.fdocument.pub/reader036/viewer/2022081511/5871b08e1a28abda6a8b6825/html5/thumbnails/24.jpg)
#ISAOcorp
クロスプラットフォームしかない
![Page 25: OnsenUI + AngularJS + CloudEndpointsで作るSPA 地雷処理の巻](https://reader036.fdocument.pub/reader036/viewer/2022081511/5871b08e1a28abda6a8b6825/html5/thumbnails/25.jpg)
Olsen UI + AngularJS + Cloud Endpoints
Single Page Application
![Page 26: OnsenUI + AngularJS + CloudEndpointsで作るSPA 地雷処理の巻](https://reader036.fdocument.pub/reader036/viewer/2022081511/5871b08e1a28abda6a8b6825/html5/thumbnails/26.jpg)
#ISAOcorp
インストール不要審査不要バージョンアップが楽アプリに近い使い勝手
![Page 27: OnsenUI + AngularJS + CloudEndpointsで作るSPA 地雷処理の巻](https://reader036.fdocument.pub/reader036/viewer/2022081511/5871b08e1a28abda6a8b6825/html5/thumbnails/27.jpg)
#ISAOcorp
OnsenUI
![Page 28: OnsenUI + AngularJS + CloudEndpointsで作るSPA 地雷処理の巻](https://reader036.fdocument.pub/reader036/viewer/2022081511/5871b08e1a28abda6a8b6825/html5/thumbnails/28.jpg)
#ISAOcorp
ブラウザ上でアプリライクな UIを簡単に表現できるフレームワークhttps://ja.onsen.io/
![Page 29: OnsenUI + AngularJS + CloudEndpointsで作るSPA 地雷処理の巻](https://reader036.fdocument.pub/reader036/viewer/2022081511/5871b08e1a28abda6a8b6825/html5/thumbnails/29.jpg)
![Page 30: OnsenUI + AngularJS + CloudEndpointsで作るSPA 地雷処理の巻](https://reader036.fdocument.pub/reader036/viewer/2022081511/5871b08e1a28abda6a8b6825/html5/thumbnails/30.jpg)
#ISAOcorp
vs Ionichttp://ionicframework.com/
![Page 31: OnsenUI + AngularJS + CloudEndpointsで作るSPA 地雷処理の巻](https://reader036.fdocument.pub/reader036/viewer/2022081511/5871b08e1a28abda6a8b6825/html5/thumbnails/31.jpg)
#ISAOcorp
日本発
![Page 32: OnsenUI + AngularJS + CloudEndpointsで作るSPA 地雷処理の巻](https://reader036.fdocument.pub/reader036/viewer/2022081511/5871b08e1a28abda6a8b6825/html5/thumbnails/32.jpg)
https://ja.monaca.io/
![Page 33: OnsenUI + AngularJS + CloudEndpointsで作るSPA 地雷処理の巻](https://reader036.fdocument.pub/reader036/viewer/2022081511/5871b08e1a28abda6a8b6825/html5/thumbnails/33.jpg)
#ISAOcorp
使ってみた感想
![Page 34: OnsenUI + AngularJS + CloudEndpointsで作るSPA 地雷処理の巻](https://reader036.fdocument.pub/reader036/viewer/2022081511/5871b08e1a28abda6a8b6825/html5/thumbnails/34.jpg)
#ISAOcorp
日本語ドキュメントが良い
![Page 35: OnsenUI + AngularJS + CloudEndpointsで作るSPA 地雷処理の巻](https://reader036.fdocument.pub/reader036/viewer/2022081511/5871b08e1a28abda6a8b6825/html5/thumbnails/35.jpg)
https://ja.onsen.io/v1/guide.html
![Page 36: OnsenUI + AngularJS + CloudEndpointsで作るSPA 地雷処理の巻](https://reader036.fdocument.pub/reader036/viewer/2022081511/5871b08e1a28abda6a8b6825/html5/thumbnails/36.jpg)
#ISAOcorp
ページスタック
![Page 37: OnsenUI + AngularJS + CloudEndpointsで作るSPA 地雷処理の巻](https://reader036.fdocument.pub/reader036/viewer/2022081511/5871b08e1a28abda6a8b6825/html5/thumbnails/37.jpg)
#ISAOcorp
navigation.pushPage()
navigation.popPage()
![Page 38: OnsenUI + AngularJS + CloudEndpointsで作るSPA 地雷処理の巻](https://reader036.fdocument.pub/reader036/viewer/2022081511/5871b08e1a28abda6a8b6825/html5/thumbnails/38.jpg)
#ISAOcorp
タブバー
![Page 39: OnsenUI + AngularJS + CloudEndpointsで作るSPA 地雷処理の巻](https://reader036.fdocument.pub/reader036/viewer/2022081511/5871b08e1a28abda6a8b6825/html5/thumbnails/39.jpg)
#ISAOcorp
![Page 40: OnsenUI + AngularJS + CloudEndpointsで作るSPA 地雷処理の巻](https://reader036.fdocument.pub/reader036/viewer/2022081511/5871b08e1a28abda6a8b6825/html5/thumbnails/40.jpg)
#ISAOcorp
タブバー & バッチ 実装のしやすさ
OnsenUI > iOS >>>>( 超えられない壁 )>>>> Android
![Page 41: OnsenUI + AngularJS + CloudEndpointsで作るSPA 地雷処理の巻](https://reader036.fdocument.pub/reader036/viewer/2022081511/5871b08e1a28abda6a8b6825/html5/thumbnails/41.jpg)
#ISAOcorp
http://qiita.com/furu8ma/items/90482dceeea8cfb162af
![Page 42: OnsenUI + AngularJS + CloudEndpointsで作るSPA 地雷処理の巻](https://reader036.fdocument.pub/reader036/viewer/2022081511/5871b08e1a28abda6a8b6825/html5/thumbnails/42.jpg)
#ISAOcorp
テーマローラー
![Page 43: OnsenUI + AngularJS + CloudEndpointsで作るSPA 地雷処理の巻](https://reader036.fdocument.pub/reader036/viewer/2022081511/5871b08e1a28abda6a8b6825/html5/thumbnails/43.jpg)
#ISAOcorp
http://components.onsen.io/
![Page 44: OnsenUI + AngularJS + CloudEndpointsで作るSPA 地雷処理の巻](https://reader036.fdocument.pub/reader036/viewer/2022081511/5871b08e1a28abda6a8b6825/html5/thumbnails/44.jpg)
#ISAOcorp
デフォルトのコンポーネントデザインで使うなら楽
![Page 45: OnsenUI + AngularJS + CloudEndpointsで作るSPA 地雷処理の巻](https://reader036.fdocument.pub/reader036/viewer/2022081511/5871b08e1a28abda6a8b6825/html5/thumbnails/45.jpg)
#ISAOcorp
コンポーネントが少ないのでカバーしていないことをやろうとすると大変
![Page 46: OnsenUI + AngularJS + CloudEndpointsで作るSPA 地雷処理の巻](https://reader036.fdocument.pub/reader036/viewer/2022081511/5871b08e1a28abda6a8b6825/html5/thumbnails/46.jpg)
デフォルトで行こう!
![Page 47: OnsenUI + AngularJS + CloudEndpointsで作るSPA 地雷処理の巻](https://reader036.fdocument.pub/reader036/viewer/2022081511/5871b08e1a28abda6a8b6825/html5/thumbnails/47.jpg)
#ISAOcorp
AngularJS
![Page 48: OnsenUI + AngularJS + CloudEndpointsで作るSPA 地雷処理の巻](https://reader036.fdocument.pub/reader036/viewer/2022081511/5871b08e1a28abda6a8b6825/html5/thumbnails/48.jpg)
![Page 49: OnsenUI + AngularJS + CloudEndpointsで作るSPA 地雷処理の巻](https://reader036.fdocument.pub/reader036/viewer/2022081511/5871b08e1a28abda6a8b6825/html5/thumbnails/49.jpg)
#ISAOcorp
dotInstall にチュートリアルがあるのでとっかかりやすい
![Page 50: OnsenUI + AngularJS + CloudEndpointsで作るSPA 地雷処理の巻](https://reader036.fdocument.pub/reader036/viewer/2022081511/5871b08e1a28abda6a8b6825/html5/thumbnails/50.jpg)
#ISAOcorphttp://dotinstall.com/lessons/basic_angularjs/8201
![Page 51: OnsenUI + AngularJS + CloudEndpointsで作るSPA 地雷処理の巻](https://reader036.fdocument.pub/reader036/viewer/2022081511/5871b08e1a28abda6a8b6825/html5/thumbnails/51.jpg)
#ISAOcorp
使ってみた感想
![Page 52: OnsenUI + AngularJS + CloudEndpointsで作るSPA 地雷処理の巻](https://reader036.fdocument.pub/reader036/viewer/2022081511/5871b08e1a28abda6a8b6825/html5/thumbnails/52.jpg)
#ISAOcorp
双方向データバインディング
![Page 53: OnsenUI + AngularJS + CloudEndpointsで作るSPA 地雷処理の巻](https://reader036.fdocument.pub/reader036/viewer/2022081511/5871b08e1a28abda6a8b6825/html5/thumbnails/53.jpg)
#ISAOcorp
$scope
![Page 54: OnsenUI + AngularJS + CloudEndpointsで作るSPA 地雷処理の巻](https://reader036.fdocument.pub/reader036/viewer/2022081511/5871b08e1a28abda6a8b6825/html5/thumbnails/54.jpg)
#ISAOcorp
フィルター
![Page 55: OnsenUI + AngularJS + CloudEndpointsで作るSPA 地雷処理の巻](https://reader036.fdocument.pub/reader036/viewer/2022081511/5871b08e1a28abda6a8b6825/html5/thumbnails/55.jpg)
#ISAOcorp
![Page 56: OnsenUI + AngularJS + CloudEndpointsで作るSPA 地雷処理の巻](https://reader036.fdocument.pub/reader036/viewer/2022081511/5871b08e1a28abda6a8b6825/html5/thumbnails/56.jpg)
#ISAOcorp
役割分担
![Page 57: OnsenUI + AngularJS + CloudEndpointsで作るSPA 地雷処理の巻](https://reader036.fdocument.pub/reader036/viewer/2022081511/5871b08e1a28abda6a8b6825/html5/thumbnails/57.jpg)
#ISAOcorp
![Page 58: OnsenUI + AngularJS + CloudEndpointsで作るSPA 地雷処理の巻](https://reader036.fdocument.pub/reader036/viewer/2022081511/5871b08e1a28abda6a8b6825/html5/thumbnails/58.jpg)
#ISAOcorp
CloudEndpoints とのデータのやり取り共通処理
各テンプレートごとの固有処理
![Page 59: OnsenUI + AngularJS + CloudEndpointsで作るSPA 地雷処理の巻](https://reader036.fdocument.pub/reader036/viewer/2022081511/5871b08e1a28abda6a8b6825/html5/thumbnails/59.jpg)
#ISAOcorp
やり方を強制されるので楽
![Page 60: OnsenUI + AngularJS + CloudEndpointsで作るSPA 地雷処理の巻](https://reader036.fdocument.pub/reader036/viewer/2022081511/5871b08e1a28abda6a8b6825/html5/thumbnails/60.jpg)
#ISAOcorp
プロダクトとしての寿命が心配
![Page 61: OnsenUI + AngularJS + CloudEndpointsで作るSPA 地雷処理の巻](https://reader036.fdocument.pub/reader036/viewer/2022081511/5871b08e1a28abda6a8b6825/html5/thumbnails/61.jpg)
仕組みに乗っかろう!
![Page 62: OnsenUI + AngularJS + CloudEndpointsで作るSPA 地雷処理の巻](https://reader036.fdocument.pub/reader036/viewer/2022081511/5871b08e1a28abda6a8b6825/html5/thumbnails/62.jpg)
#ISAOcorp
CloudEndpoints
![Page 63: OnsenUI + AngularJS + CloudEndpointsで作るSPA 地雷処理の巻](https://reader036.fdocument.pub/reader036/viewer/2022081511/5871b08e1a28abda6a8b6825/html5/thumbnails/63.jpg)
#ISAOcorp
Platformasa Service
![Page 64: OnsenUI + AngularJS + CloudEndpointsで作るSPA 地雷処理の巻](https://reader036.fdocument.pub/reader036/viewer/2022081511/5871b08e1a28abda6a8b6825/html5/thumbnails/64.jpg)
![Page 65: OnsenUI + AngularJS + CloudEndpointsで作るSPA 地雷処理の巻](https://reader036.fdocument.pub/reader036/viewer/2022081511/5871b08e1a28abda6a8b6825/html5/thumbnails/65.jpg)
#ISAOcorp
BackendAPI を簡単に生成
![Page 66: OnsenUI + AngularJS + CloudEndpointsで作るSPA 地雷処理の巻](https://reader036.fdocument.pub/reader036/viewer/2022081511/5871b08e1a28abda6a8b6825/html5/thumbnails/66.jpg)
インフラらく〜
![Page 67: OnsenUI + AngularJS + CloudEndpointsで作るSPA 地雷処理の巻](https://reader036.fdocument.pub/reader036/viewer/2022081511/5871b08e1a28abda6a8b6825/html5/thumbnails/67.jpg)
#ISAOcorp
vs Parsehttps://parse.com/
vs Herokuhttps://www.heroku.com/
![Page 68: OnsenUI + AngularJS + CloudEndpointsで作るSPA 地雷処理の巻](https://reader036.fdocument.pub/reader036/viewer/2022081511/5871b08e1a28abda6a8b6825/html5/thumbnails/68.jpg)
#ISAOcorp
使ってみたかった
![Page 69: OnsenUI + AngularJS + CloudEndpointsで作るSPA 地雷処理の巻](https://reader036.fdocument.pub/reader036/viewer/2022081511/5871b08e1a28abda6a8b6825/html5/thumbnails/69.jpg)
#ISAOcorp
Cloud Datastore
![Page 70: OnsenUI + AngularJS + CloudEndpointsで作るSPA 地雷処理の巻](https://reader036.fdocument.pub/reader036/viewer/2022081511/5871b08e1a28abda6a8b6825/html5/thumbnails/70.jpg)
#ISAOcorp
NoSQL
![Page 71: OnsenUI + AngularJS + CloudEndpointsで作るSPA 地雷処理の巻](https://reader036.fdocument.pub/reader036/viewer/2022081511/5871b08e1a28abda6a8b6825/html5/thumbnails/71.jpg)
#ISAOcorp
Auto scale
![Page 72: OnsenUI + AngularJS + CloudEndpointsで作るSPA 地雷処理の巻](https://reader036.fdocument.pub/reader036/viewer/2022081511/5871b08e1a28abda6a8b6825/html5/thumbnails/72.jpg)
インフラらく〜
![Page 73: OnsenUI + AngularJS + CloudEndpointsで作るSPA 地雷処理の巻](https://reader036.fdocument.pub/reader036/viewer/2022081511/5871b08e1a28abda6a8b6825/html5/thumbnails/73.jpg)
#ISAOcorp
使ってみた感想
![Page 74: OnsenUI + AngularJS + CloudEndpointsで作るSPA 地雷処理の巻](https://reader036.fdocument.pub/reader036/viewer/2022081511/5871b08e1a28abda6a8b6825/html5/thumbnails/74.jpg)
#ISAOcorp
良いチュートリアルがある
![Page 75: OnsenUI + AngularJS + CloudEndpointsで作るSPA 地雷処理の巻](https://reader036.fdocument.pub/reader036/viewer/2022081511/5871b08e1a28abda6a8b6825/html5/thumbnails/75.jpg)
#ISAOcorp
https://rominirani.com/google-cloud-endpoints-tutorial-part-1-b571ad6c7cd2#.y8qydbm5t
![Page 76: OnsenUI + AngularJS + CloudEndpointsで作るSPA 地雷処理の巻](https://reader036.fdocument.pub/reader036/viewer/2022081511/5871b08e1a28abda6a8b6825/html5/thumbnails/76.jpg)
#ISAOcorp
SDK 充実https://cloud.google.com/appengine/docs/java/endpoints/#basic_endpoints_architecture
![Page 77: OnsenUI + AngularJS + CloudEndpointsで作るSPA 地雷処理の巻](https://reader036.fdocument.pub/reader036/viewer/2022081511/5871b08e1a28abda6a8b6825/html5/thumbnails/77.jpg)
![Page 78: OnsenUI + AngularJS + CloudEndpointsで作るSPA 地雷処理の巻](https://reader036.fdocument.pub/reader036/viewer/2022081511/5871b08e1a28abda6a8b6825/html5/thumbnails/78.jpg)
![Page 79: OnsenUI + AngularJS + CloudEndpointsで作るSPA 地雷処理の巻](https://reader036.fdocument.pub/reader036/viewer/2022081511/5871b08e1a28abda6a8b6825/html5/thumbnails/79.jpg)
#ISAOcorp
デプロイ簡単appcfg.py -A hogehoge-project update appengine-try-
php
![Page 80: OnsenUI + AngularJS + CloudEndpointsで作るSPA 地雷処理の巻](https://reader036.fdocument.pub/reader036/viewer/2022081511/5871b08e1a28abda6a8b6825/html5/thumbnails/80.jpg)
#ISAOcorp
ロールバック簡単
![Page 81: OnsenUI + AngularJS + CloudEndpointsで作るSPA 地雷処理の巻](https://reader036.fdocument.pub/reader036/viewer/2022081511/5871b08e1a28abda6a8b6825/html5/thumbnails/81.jpg)
#ISAOcorp
![Page 82: OnsenUI + AngularJS + CloudEndpointsで作るSPA 地雷処理の巻](https://reader036.fdocument.pub/reader036/viewer/2022081511/5871b08e1a28abda6a8b6825/html5/thumbnails/82.jpg)
#ISAOcorp
エッジキャッシュ
![Page 83: OnsenUI + AngularJS + CloudEndpointsで作るSPA 地雷処理の巻](https://reader036.fdocument.pub/reader036/viewer/2022081511/5871b08e1a28abda6a8b6825/html5/thumbnails/83.jpg)
#ISAOcorp
安い
![Page 85: OnsenUI + AngularJS + CloudEndpointsで作るSPA 地雷処理の巻](https://reader036.fdocument.pub/reader036/viewer/2022081511/5871b08e1a28abda6a8b6825/html5/thumbnails/85.jpg)
#ISAOcorp
http://koni.hateblo.jp/entry/2016/01/06/130613
![Page 86: OnsenUI + AngularJS + CloudEndpointsで作るSPA 地雷処理の巻](https://reader036.fdocument.pub/reader036/viewer/2022081511/5871b08e1a28abda6a8b6825/html5/thumbnails/86.jpg)
#ISAOcorp
![Page 87: OnsenUI + AngularJS + CloudEndpointsで作るSPA 地雷処理の巻](https://reader036.fdocument.pub/reader036/viewer/2022081511/5871b08e1a28abda6a8b6825/html5/thumbnails/87.jpg)
#ISAOcorp
スピンアップ問題
![Page 88: OnsenUI + AngularJS + CloudEndpointsで作るSPA 地雷処理の巻](https://reader036.fdocument.pub/reader036/viewer/2022081511/5871b08e1a28abda6a8b6825/html5/thumbnails/88.jpg)
かんたん!
![Page 89: OnsenUI + AngularJS + CloudEndpointsで作るSPA 地雷処理の巻](https://reader036.fdocument.pub/reader036/viewer/2022081511/5871b08e1a28abda6a8b6825/html5/thumbnails/89.jpg)
#ISAOcorp
• 背景作ったもの踏んだ地雷フィードバック
![Page 90: OnsenUI + AngularJS + CloudEndpointsで作るSPA 地雷処理の巻](https://reader036.fdocument.pub/reader036/viewer/2022081511/5871b08e1a28abda6a8b6825/html5/thumbnails/90.jpg)
#ISAOcorp
シェアシステム
![Page 91: OnsenUI + AngularJS + CloudEndpointsで作るSPA 地雷処理の巻](https://reader036.fdocument.pub/reader036/viewer/2022081511/5871b08e1a28abda6a8b6825/html5/thumbnails/91.jpg)
#ISAOcorp
カレンダーを使って予約日時を指定したい
![Page 92: OnsenUI + AngularJS + CloudEndpointsで作るSPA 地雷処理の巻](https://reader036.fdocument.pub/reader036/viewer/2022081511/5871b08e1a28abda6a8b6825/html5/thumbnails/92.jpg)
OnsenUI にカレンダーないじゃん!
![Page 93: OnsenUI + AngularJS + CloudEndpointsで作るSPA 地雷処理の巻](https://reader036.fdocument.pub/reader036/viewer/2022081511/5871b08e1a28abda6a8b6825/html5/thumbnails/93.jpg)
#ISAOcorp
どうする?
![Page 94: OnsenUI + AngularJS + CloudEndpointsで作るSPA 地雷処理の巻](https://reader036.fdocument.pub/reader036/viewer/2022081511/5871b08e1a28abda6a8b6825/html5/thumbnails/94.jpg)
#ISAOcorp
自作?
![Page 95: OnsenUI + AngularJS + CloudEndpointsで作るSPA 地雷処理の巻](https://reader036.fdocument.pub/reader036/viewer/2022081511/5871b08e1a28abda6a8b6825/html5/thumbnails/95.jpg)
そんな時間ないよ〜!
![Page 96: OnsenUI + AngularJS + CloudEndpointsで作るSPA 地雷処理の巻](https://reader036.fdocument.pub/reader036/viewer/2022081511/5871b08e1a28abda6a8b6825/html5/thumbnails/96.jpg)
http://fullcalendar.io/
![Page 97: OnsenUI + AngularJS + CloudEndpointsで作るSPA 地雷処理の巻](https://reader036.fdocument.pub/reader036/viewer/2022081511/5871b08e1a28abda6a8b6825/html5/thumbnails/97.jpg)
かんたん!
![Page 98: OnsenUI + AngularJS + CloudEndpointsで作るSPA 地雷処理の巻](https://reader036.fdocument.pub/reader036/viewer/2022081511/5871b08e1a28abda6a8b6825/html5/thumbnails/98.jpg)
#ISAOcorp
日時はタップだけで選択したい
![Page 99: OnsenUI + AngularJS + CloudEndpointsで作るSPA 地雷処理の巻](https://reader036.fdocument.pub/reader036/viewer/2022081511/5871b08e1a28abda6a8b6825/html5/thumbnails/99.jpg)
OnsenUI にDate picker
ないじゃん!
![Page 100: OnsenUI + AngularJS + CloudEndpointsで作るSPA 地雷処理の巻](https://reader036.fdocument.pub/reader036/viewer/2022081511/5871b08e1a28abda6a8b6825/html5/thumbnails/100.jpg)
https://github.com/alongubkin/angular-datepicker
![Page 101: OnsenUI + AngularJS + CloudEndpointsで作るSPA 地雷処理の巻](https://reader036.fdocument.pub/reader036/viewer/2022081511/5871b08e1a28abda6a8b6825/html5/thumbnails/101.jpg)
これならなんとか
![Page 102: OnsenUI + AngularJS + CloudEndpointsで作るSPA 地雷処理の巻](https://reader036.fdocument.pub/reader036/viewer/2022081511/5871b08e1a28abda6a8b6825/html5/thumbnails/102.jpg)
#ISAOcorp
つくった
![Page 103: OnsenUI + AngularJS + CloudEndpointsで作るSPA 地雷処理の巻](https://reader036.fdocument.pub/reader036/viewer/2022081511/5871b08e1a28abda6a8b6825/html5/thumbnails/103.jpg)
![Page 104: OnsenUI + AngularJS + CloudEndpointsで作るSPA 地雷処理の巻](https://reader036.fdocument.pub/reader036/viewer/2022081511/5871b08e1a28abda6a8b6825/html5/thumbnails/104.jpg)
#ISAOcorp
FullCalendar.js
+angular-datepicker
OnsenUI
![Page 105: OnsenUI + AngularJS + CloudEndpointsで作るSPA 地雷処理の巻](https://reader036.fdocument.pub/reader036/viewer/2022081511/5871b08e1a28abda6a8b6825/html5/thumbnails/105.jpg)
OnsenUIすくないね…
![Page 106: OnsenUI + AngularJS + CloudEndpointsで作るSPA 地雷処理の巻](https://reader036.fdocument.pub/reader036/viewer/2022081511/5871b08e1a28abda6a8b6825/html5/thumbnails/106.jpg)
#ISAOcorp
• 背景作ったもの踏んだ地雷フィードバック
![Page 107: OnsenUI + AngularJS + CloudEndpointsで作るSPA 地雷処理の巻](https://reader036.fdocument.pub/reader036/viewer/2022081511/5871b08e1a28abda6a8b6825/html5/thumbnails/107.jpg)
#ISAOcorp
初期値が設定できないiOS でイベントが発生しないAndroid でイベントが発生しないCloudEndpoints がクエリを受け付けない
![Page 108: OnsenUI + AngularJS + CloudEndpointsで作るSPA 地雷処理の巻](https://reader036.fdocument.pub/reader036/viewer/2022081511/5871b08e1a28abda6a8b6825/html5/thumbnails/108.jpg)
#ISAOcorp
初期値が設定できないiOS でイベントが発生しないAndroid でイベントが発生しないCloudEndpoints がクエリを受け付けない
![Page 109: OnsenUI + AngularJS + CloudEndpointsで作るSPA 地雷処理の巻](https://reader036.fdocument.pub/reader036/viewer/2022081511/5871b08e1a28abda6a8b6825/html5/thumbnails/109.jpg)
初期値が設定できない
![Page 110: OnsenUI + AngularJS + CloudEndpointsで作るSPA 地雷処理の巻](https://reader036.fdocument.pub/reader036/viewer/2022081511/5871b08e1a28abda6a8b6825/html5/thumbnails/110.jpg)
あれ、初期値を書く場所は?
template.html
![Page 111: OnsenUI + AngularJS + CloudEndpointsで作るSPA 地雷処理の巻](https://reader036.fdocument.pub/reader036/viewer/2022081511/5871b08e1a28abda6a8b6825/html5/thumbnails/111.jpg)
想定外すぎる!
![Page 112: OnsenUI + AngularJS + CloudEndpointsで作るSPA 地雷処理の巻](https://reader036.fdocument.pub/reader036/viewer/2022081511/5871b08e1a28abda6a8b6825/html5/thumbnails/112.jpg)
#ISAOcorp
どうする?
![Page 113: OnsenUI + AngularJS + CloudEndpointsで作るSPA 地雷処理の巻](https://reader036.fdocument.pub/reader036/viewer/2022081511/5871b08e1a28abda6a8b6825/html5/thumbnails/113.jpg)
#ISAOcorp
angular-datepickerのコードを読む
![Page 114: OnsenUI + AngularJS + CloudEndpointsで作るSPA 地雷処理の巻](https://reader036.fdocument.pub/reader036/viewer/2022081511/5871b08e1a28abda6a8b6825/html5/thumbnails/114.jpg)
直接 DOM を操作
controller.js
![Page 115: OnsenUI + AngularJS + CloudEndpointsで作るSPA 地雷処理の巻](https://reader036.fdocument.pub/reader036/viewer/2022081511/5871b08e1a28abda6a8b6825/html5/thumbnails/115.jpg)
DOM を直接操作するなんてママに叱られる〜
![Page 116: OnsenUI + AngularJS + CloudEndpointsで作るSPA 地雷処理の巻](https://reader036.fdocument.pub/reader036/viewer/2022081511/5871b08e1a28abda6a8b6825/html5/thumbnails/116.jpg)
#ISAOcorp
初期値が設定できないiOS でイベントが発生しないAndroid でイベントが発生しないCloudEndpoints がクエリを受け付けない
![Page 117: OnsenUI + AngularJS + CloudEndpointsで作るSPA 地雷処理の巻](https://reader036.fdocument.pub/reader036/viewer/2022081511/5871b08e1a28abda6a8b6825/html5/thumbnails/117.jpg)
iPhone がタッチに反応しない
タップしてるのに…
![Page 118: OnsenUI + AngularJS + CloudEndpointsで作るSPA 地雷処理の巻](https://reader036.fdocument.pub/reader036/viewer/2022081511/5871b08e1a28abda6a8b6825/html5/thumbnails/118.jpg)
FullCalendar#dayClickイベントが発火しない〜
![Page 119: OnsenUI + AngularJS + CloudEndpointsで作るSPA 地雷処理の巻](https://reader036.fdocument.pub/reader036/viewer/2022081511/5871b08e1a28abda6a8b6825/html5/thumbnails/119.jpg)
#ISAOcorp
どうする?
![Page 120: OnsenUI + AngularJS + CloudEndpointsで作るSPA 地雷処理の巻](https://reader036.fdocument.pub/reader036/viewer/2022081511/5871b08e1a28abda6a8b6825/html5/thumbnails/120.jpg)
#ISAOcorp
FullCalendar.jsのコードを読む
![Page 121: OnsenUI + AngularJS + CloudEndpointsで作るSPA 地雷処理の巻](https://reader036.fdocument.pub/reader036/viewer/2022081511/5871b08e1a28abda6a8b6825/html5/thumbnails/121.jpg)
タップ > ドラック終了 > 発火
タップ > ドラック終了ではない > 未発火
![Page 122: OnsenUI + AngularJS + CloudEndpointsで作るSPA 地雷処理の巻](https://reader036.fdocument.pub/reader036/viewer/2022081511/5871b08e1a28abda6a8b6825/html5/thumbnails/122.jpg)
http://qiita.com/furu8ma/items/1af80a6d8ab369e115d0
![Page 123: OnsenUI + AngularJS + CloudEndpointsで作るSPA 地雷処理の巻](https://reader036.fdocument.pub/reader036/viewer/2022081511/5871b08e1a28abda6a8b6825/html5/thumbnails/123.jpg)
ライブラリに手を入れるなんてママに叱られる〜
![Page 124: OnsenUI + AngularJS + CloudEndpointsで作るSPA 地雷処理の巻](https://reader036.fdocument.pub/reader036/viewer/2022081511/5871b08e1a28abda6a8b6825/html5/thumbnails/124.jpg)
#ISAOcorp
初期値が設定できないiOS でイベントが発生しないAndroid でイベントが発生しないCloudEndpoints がクエリを受け付けない
![Page 125: OnsenUI + AngularJS + CloudEndpointsで作るSPA 地雷処理の巻](https://reader036.fdocument.pub/reader036/viewer/2022081511/5871b08e1a28abda6a8b6825/html5/thumbnails/125.jpg)
4.4 より前の Android で空の日セルをタップしても反応しない
![Page 126: OnsenUI + AngularJS + CloudEndpointsで作るSPA 地雷処理の巻](https://reader036.fdocument.pub/reader036/viewer/2022081511/5871b08e1a28abda6a8b6825/html5/thumbnails/126.jpg)
#ISAOcorp
どうする?
![Page 127: OnsenUI + AngularJS + CloudEndpointsで作るSPA 地雷処理の巻](https://reader036.fdocument.pub/reader036/viewer/2022081511/5871b08e1a28abda6a8b6825/html5/thumbnails/127.jpg)
#ISAOcorp
FullCalendar.jsのコードを読む
![Page 128: OnsenUI + AngularJS + CloudEndpointsで作るSPA 地雷処理の巻](https://reader036.fdocument.pub/reader036/viewer/2022081511/5871b08e1a28abda6a8b6825/html5/thumbnails/128.jpg)
わからないよ〜
![Page 129: OnsenUI + AngularJS + CloudEndpointsで作るSPA 地雷処理の巻](https://reader036.fdocument.pub/reader036/viewer/2022081511/5871b08e1a28abda6a8b6825/html5/thumbnails/129.jpg)
原因不明。期限だけが近づいてくる… .
![Page 130: OnsenUI + AngularJS + CloudEndpointsで作るSPA 地雷処理の巻](https://reader036.fdocument.pub/reader036/viewer/2022081511/5871b08e1a28abda6a8b6825/html5/thumbnails/130.jpg)
空のイベントを全ての日に設定
![Page 131: OnsenUI + AngularJS + CloudEndpointsで作るSPA 地雷処理の巻](https://reader036.fdocument.pub/reader036/viewer/2022081511/5871b08e1a28abda6a8b6825/html5/thumbnails/131.jpg)
力技すぎてママに叱られる〜
![Page 132: OnsenUI + AngularJS + CloudEndpointsで作るSPA 地雷処理の巻](https://reader036.fdocument.pub/reader036/viewer/2022081511/5871b08e1a28abda6a8b6825/html5/thumbnails/132.jpg)
#ISAOcorp
初期値が設定できないiOS でイベントが発生しないAndroid でイベントが発生しないCloudEndpoints がクエリを受け付けない
![Page 133: OnsenUI + AngularJS + CloudEndpointsで作るSPA 地雷処理の巻](https://reader036.fdocument.pub/reader036/viewer/2022081511/5871b08e1a28abda6a8b6825/html5/thumbnails/133.jpg)
#ISAOcorp
リリース直前すべてのクエリを受け付けなくなる
![Page 134: OnsenUI + AngularJS + CloudEndpointsで作るSPA 地雷処理の巻](https://reader036.fdocument.pub/reader036/viewer/2022081511/5871b08e1a28abda6a8b6825/html5/thumbnails/134.jpg)
#ISAOcorp
どうする?
![Page 135: OnsenUI + AngularJS + CloudEndpointsで作るSPA 地雷処理の巻](https://reader036.fdocument.pub/reader036/viewer/2022081511/5871b08e1a28abda6a8b6825/html5/thumbnails/135.jpg)
#ISAOcorp
ググる
![Page 136: OnsenUI + AngularJS + CloudEndpointsで作るSPA 地雷処理の巻](https://reader036.fdocument.pub/reader036/viewer/2022081511/5871b08e1a28abda6a8b6825/html5/thumbnails/136.jpg)
#ISAOcorp
Cloud Datastoreのquota 問題だった
![Page 137: OnsenUI + AngularJS + CloudEndpointsで作るSPA 地雷処理の巻](https://reader036.fdocument.pub/reader036/viewer/2022081511/5871b08e1a28abda6a8b6825/html5/thumbnails/137.jpg)
#ISAOcorphttp://qiita.com/furu8ma/items/399b39028b13259937ab
![Page 138: OnsenUI + AngularJS + CloudEndpointsで作るSPA 地雷処理の巻](https://reader036.fdocument.pub/reader036/viewer/2022081511/5871b08e1a28abda6a8b6825/html5/thumbnails/138.jpg)
OnsenUI,AngularJSの問題じゃないじゃん
![Page 139: OnsenUI + AngularJS + CloudEndpointsで作るSPA 地雷処理の巻](https://reader036.fdocument.pub/reader036/viewer/2022081511/5871b08e1a28abda6a8b6825/html5/thumbnails/139.jpg)
#ISAOcorp
• 背景作ったもの踏んだ地雷フィードバック
![Page 140: OnsenUI + AngularJS + CloudEndpointsで作るSPA 地雷処理の巻](https://reader036.fdocument.pub/reader036/viewer/2022081511/5871b08e1a28abda6a8b6825/html5/thumbnails/140.jpg)
#ISAOcorp
カレンダーを自作したことはありますか?
![Page 141: OnsenUI + AngularJS + CloudEndpointsで作るSPA 地雷処理の巻](https://reader036.fdocument.pub/reader036/viewer/2022081511/5871b08e1a28abda6a8b6825/html5/thumbnails/141.jpg)
#ISAOcorp
その JS ライブラリは本当にクロスプラットフォームですか?
![Page 142: OnsenUI + AngularJS + CloudEndpointsで作るSPA 地雷処理の巻](https://reader036.fdocument.pub/reader036/viewer/2022081511/5871b08e1a28abda6a8b6825/html5/thumbnails/142.jpg)
#ISAOcorp
OnsenUIAngularJS
CloudEndpointsFullCalendar.js
angular-datepicker
検証をおろそかにしがち
![Page 143: OnsenUI + AngularJS + CloudEndpointsで作るSPA 地雷処理の巻](https://reader036.fdocument.pub/reader036/viewer/2022081511/5871b08e1a28abda6a8b6825/html5/thumbnails/143.jpg)
そんなこと言ったってライブラリを使わない
なんて無理!
![Page 144: OnsenUI + AngularJS + CloudEndpointsで作るSPA 地雷処理の巻](https://reader036.fdocument.pub/reader036/viewer/2022081511/5871b08e1a28abda6a8b6825/html5/thumbnails/144.jpg)
#ISAOcorp
ネイティブアプリという選択
![Page 145: OnsenUI + AngularJS + CloudEndpointsで作るSPA 地雷処理の巻](https://reader036.fdocument.pub/reader036/viewer/2022081511/5871b08e1a28abda6a8b6825/html5/thumbnails/145.jpg)
#ISAOcorp
クロスプラットフォームはハマった時に手を入れるのが大変
![Page 146: OnsenUI + AngularJS + CloudEndpointsで作るSPA 地雷処理の巻](https://reader036.fdocument.pub/reader036/viewer/2022081511/5871b08e1a28abda6a8b6825/html5/thumbnails/146.jpg)
急がば自作かも
![Page 147: OnsenUI + AngularJS + CloudEndpointsで作るSPA 地雷処理の巻](https://reader036.fdocument.pub/reader036/viewer/2022081511/5871b08e1a28abda6a8b6825/html5/thumbnails/147.jpg)
#ISAOcorp
質問タイム
![Page 148: OnsenUI + AngularJS + CloudEndpointsで作るSPA 地雷処理の巻](https://reader036.fdocument.pub/reader036/viewer/2022081511/5871b08e1a28abda6a8b6825/html5/thumbnails/148.jpg)
#ISAOcorp
最後に
![Page 149: OnsenUI + AngularJS + CloudEndpointsで作るSPA 地雷処理の巻](https://reader036.fdocument.pub/reader036/viewer/2022081511/5871b08e1a28abda6a8b6825/html5/thumbnails/149.jpg)
#ISAOcorp
エンジニア募集中
![Page 150: OnsenUI + AngularJS + CloudEndpointsで作るSPA 地雷処理の巻](https://reader036.fdocument.pub/reader036/viewer/2022081511/5871b08e1a28abda6a8b6825/html5/thumbnails/150.jpg)
![Page 151: OnsenUI + AngularJS + CloudEndpointsで作るSPA 地雷処理の巻](https://reader036.fdocument.pub/reader036/viewer/2022081511/5871b08e1a28abda6a8b6825/html5/thumbnails/151.jpg)
#ISAOcorp
ありがとうございました!