9

Click here to load reader

Railsのフロントエンド開発を考える

Embed Size (px)

Citation preview

Page 1: Railsのフロントエンド開発を考える

Rails のフロントエンド開発を考える - JavaScript フレームワーク

Ruby/ Ruby on Rails ビギナーズ勉強会 第 9 回2015/12/19 平田智子

Page 2: Railsのフロントエンド開発を考える

about me•平田智子(ひらたともこ)

•新潟県生まれ、大阪出身です

•普段は vb.net で開発しています• web 勉強歴はもうすぐで1年

• Facebook:hirata.tomoko• blog:http://tomoko-tsubasa.hateblo.jp/

Page 3: Railsのフロントエンド開発を考える

agenda

•フロントエンドとバックエンド•AngularJS•Backbone.js•Knockout.js•どれを選ぶ?

Page 4: Railsのフロントエンド開発を考える

フロントエンドとバックエンド

View

Controller

Model

RubyonRailsフロントエンド側 バックエンド側

HTMLCSS

Javascript

Page 5: Railsのフロントエンド開発を考える

AngulerJS

+Rails gem 'angular-gem'

MVW(MVC) モデル

フルスタック型フレームワーク ( 双方向バインディング、ルーティング、 REST API…)

機能が多いため学習コストは高い

構造化、部品化がしやすい

TypeScript と相性が良い

公式サイト

Page 6: Railsのフロントエンド開発を考える

Backbone.js

公式サイト

MVW(MVC2) モデル

underscore.js に依存

軽量なフレームワークで自由度が高い

ルーティング機能 / サーバとの通信機能

Rails/CoffeeScript と相性が良い

+Rails( 代表例 )    gem 'rails-backbone'    gem 'backbone-on-rails'

Page 7: Railsのフロントエンド開発を考える

Knockout.js

公式サイト

MVVM モデル

バインディングに特化したフレームワーク

シンプルでわかりやすく学習コストは低い

構造化が弱いため大規模開発には不向き?

TypeScript と相性が良い

+Rails gem 'knockoutjs-rails'

Page 8: Railsのフロントエンド開発を考える

どれを使う?

一人でさくっと作る / 小規模の開発 → 習得済のもの or 学習コストだけなら Knockout.js

複数人で作る / 中~大規模の開発 → 既習得者がいるもの  or Backbone.js    データバインディングが重要なら AngulerJS ? 

Page 9: Railsのフロントエンド開発を考える

おしまい