Upgrade to Pro
— share decks privately, control downloads, hide ads and more …
Speaker Deck
Features
Speaker Deck
PRO
Sign in
Sign up for free
Search
Search
Multi-platform Mobile with Calatrava - May 2013
Search
Pete Hodgson
May 23, 2013
Programming
2
490
Multi-platform Mobile with Calatrava - May 2013
Pete Hodgson
May 23, 2013
Tweet
Share
More Decks by Pete Hodgson
See All by Pete Hodgson
Migratory Patterns - KubeCon Salt Lake City, 2024
phodgson
0
67
A Journey Into Feature Toggles - OSCON Austin 2017
phodgson
5
570
Test-driven Client-side JS
phodgson
5
810
Functional Reactive JavaScript
phodgson
8
780
different.js - Forward JS 2014
phodgson
4
810
Railsconf2014
phodgson
7
1.4k
Building Your Own Lightsaber
phodgson
104
6.3k
iOS Unit Testing Workshop
phodgson
3
500
Unit testing with Kiwi - CocoaConf San Jose 2013
phodgson
1
650
Other Decks in Programming
See All in Programming
RubyKaigi Dev Meeting 2025
tenderlove
1
110
Do Dumb Things
mitsuhiko
0
430
「影響が少ない」を自分の目でみてみる
o0h
PRO
2
1.1k
Unlock the Potential of Swift Code Generation
rockname
0
250
趣味全開のAITuber開発
kokushin
0
200
API for docs
soutaro
2
1.2k
ComposeでWebアプリを作る技術
tbsten
0
110
SQL Server ベクトル検索
odashinsuke
0
170
AIコードエディタの基盤となるLLMのFlutter性能評価
alquist4121
0
210
Develop Faster With FrankenPHP
dunglas
2
3.3k
Coding Experience Cpp vs Csharp - meetup app osaka@9
harukasao
0
740
List とは何か? / PHPerKaigi 2025
meihei3
0
860
Featured
See All Featured
BBQ
matthewcrist
88
9.6k
The Myth of the Modular Monolith - Day 2 Keynote - Rails World 2024
eileencodes
23
2.6k
What's in a price? How to price your products and services
michaelherold
245
12k
Speed Design
sergeychernyshev
29
900
The Art of Programming - Codeland 2020
erikaheidi
53
13k
Code Reviewing Like a Champion
maltzj
522
40k
Thoughts on Productivity
jonyablonski
69
4.6k
XXLCSS - How to scale CSS and keep your sanity
sugarenia
248
1.3M
The MySQL Ecosystem @ GitHub 2015
samlambert
251
12k
GraphQLとの向き合い方2022年版
quramy
46
14k
The Straight Up "How To Draw Better" Workshop
denniskardys
232
140k
The World Runs on Bad Software
bkeepers
PRO
67
11k
Transcript
Cross-platform Mobile
Pete Hodgson @ph1
Portable Body
http://martinfowler.com/articles/multiMobile/
mobile app
UI the rest
UI portable body
UI portable body
UI portable body JavaScript
UI portable body iOS JavaScript
portable body UI
portable body
portable body iPhone mobile web Android
portable body iPhone mobile web Android
iPhone mobile web Android
http://calatrava.github.io/
- controllers - domain objs. - services <html> views
- controllers - domain objs. - services <html> views
kernel UI
update UI respond to user input kernel UI
show me
None
updating the UI
updating the UI
updating the UI
updating the UI
someView.render( aViewMessage ) updating the UI
someView.render( aViewMessage ) updating the UI {...}
someView.render( aViewMessage ) updating the UI {...}
reading the UI
` reading the UI
someView.get( ‘field_id’, callbackFn ) ` reading the UI
someView.get( ‘field_id’, callbackFn ) ` reading the UI
responding to events
responding to events
responding to events `
someView.bind( ‘event_id’, callbackFn ) responding to events `
None
calatrava is HTML first
native <html> <html> <html> HTML first
native <html> <html> <html> native HTML first
native <html> <html> <html> native HTML first native
Testing Acceptance Tests
Testing Acceptance Tests app logic
where’s your logic? mobile app mobile services
shared mobile services app HTML
app shared mobile services app app iPhone HTML Android
thanks!
thanks! @ph1 for slides
www.thoughtworks.com/radar