SlideShare a Scribd company logo
with Sencha Touch 2
Martin de Keijzer
iOSOnRailsConf 2013 13-14 April, Alushta Ukraine
Building mobile web applications
Sunday, 14 April 13
Introduction
2
Sunday, 14 April 13
About me
Martin de Keijzer
Dutch web developer
3
@Martin1982
PHPBenelux Board Member
Working for Ibuildings
http://www.martindekeijzer.nl
Sunday, 14 April 13
The mobile web
4
Sunday, 14 April 13
Apps
Languages
‣ Apple: Objective-C
‣ Android: Java
‣ Windows Phone: C# / Visual Basic
5
Distribution Methods
Apple: AppStore
Android: Market
Windows Phone: Microsoft Market Place
Sunday, 14 April 13
Web Apps
6
Available through the web
Sunday, 14 April 13
Web Apps
Platform independent
7
Sunday, 14 April 13
Web Apps
Can be transformed to an App-like experience
8
Sunday, 14 April 13
Web Apps
9
Can be wrapped as native apps
Sunday, 14 April 13
Sunday, 14 April 13
The Sencha Touch way
‣ Building applications, not websites
‣ Pure JavaScript
‣ Touch framework
‣ MV(S)C Paradigm
‣ Based on ExtJS 4
Downloadable from http://www.sencha.com
11
Sunday, 14 April 13
Rapidly starting
Sencha Cmd
12
Sunday, 14 April 13
Quick start: Sencha Cmd
13
sencha generate app <name> <path>
Sunday, 14 April 13
Quick start: Sencha Cmd
14
•App
•Resources
•app.js
•.json files
•index.html
•touch (DO NOT TOUCH!)
Sunday, 14 April 13
Changing the SDK is bad! Extending is ok.
15
Sunday, 14 April 13
Testing
16
Webkit
Sunday, 14 April 13
Setting up views
Interface design
17
Sunday, 14 April 13
User interface
Abstraction of various app ui elements:
‣ containers
‣ panels
‣ tab panels
‣ carousels
‣ lists
‣ forms
‣ toolbars
18
Sunday, 14 April 13
Creating views
19app/view/Technologies.js
Sunday, 14 April 13
Creating views
20
http://docs.sencha.com
Sunday, 14 April 13
Creating views
21
/app.js
Sunday, 14 April 13
Creating views
22app/view/Main.js
Sunday, 14 April 13
Creating views
23
Sunday, 14 April 13
Bootstrapping & Controllers
Taking control
24
Sunday, 14 April 13
Bootstrapping and Controllers
25
/app.js
Final point of bootstrapping,
controllers & profiles go first
Sunday, 14 April 13
Bootstrapping and Controllers
26
Sunday, 14 April 13
Events
27
Create a new controller
sencha generate controller <name>
Sunday, 14 April 13
Events
28
Make the component selectable
Sunday, 14 April 13
Events
29app/controller/TechnologiesTab.js
Sunday, 14 April 13
Events
30
app/controller/TechnologiesTab.js
Sunday, 14 April 13
Events
31
Querying
Predefined events
Sunday, 14 April 13
Events
32app/controller/TechnologiesTab.js
Sunday, 14 April 13
Events
33
Sunday, 14 April 13
and communication
Data binding
34
Sunday, 14 April 13
Data communication
35
Sunday, 14 April 13
Model
36
Model
Field
Association Validation
Sunday, 14 April 13
Model
37
sencha generate model <name>
<property:type,[property:type]...>
Sunday, 14 April 13
Model
38app/model/Technologies.js
Sunday, 14 April 13
Store
39
Store
Model
Filter Grouper Sorter
Sunday, 14 April 13
Store
40
app/store/Technologies.js
app.js
Sunday, 14 April 13
Proxy
41
Proxy
Reader Writer
Store Model
Sunday, 14 April 13
Proxy
42
app/model/Technologies.js
Sunday, 14 April 13
Create a list
43app/view/Technologies.js
Sunday, 14 April 13
Data in action!
44
Sunday, 14 April 13
When an OS doesn’t play well with your app
Device profiles
45
Sunday, 14 April 13
Device profiles
Different devices can require different
options.
46
Sunday, 14 April 13
Device Profiles
Tablet has more screen real estate and
can provide more user interaction than
a phone.
47
Sunday, 14 April 13
Device Profiles
Device profiles provide a solution!
48
Sunday, 14 April 13
Profile setup
49
sencha generate profile <name>
Sunday, 14 April 13
Profile overriding
50
app/view/Desktop/Main.js
Sunday, 14 April 13
Profile overriding
51
app/view/Tablet/Main.js
Sunday, 14 April 13
Profile overriding
52
app/view/Phone/Main.js
Sunday, 14 April 13
Profile overriding
53
app/profile/Tablet.js
Sunday, 14 April 13
Profile overriding
54
Desktop
Sunday, 14 April 13
Profile overriding
55
Phone
Sunday, 14 April 13
Profile overriding
56
Tablet
Sunday, 14 April 13
Styling an app
Your app’s got style!
57
Sunday, 14 April 13
Sunday, 14 April 13
Installing Compass
59
gem install compass
Sunday, 14 April 13
The scss file
60
compass compile
compass watch
Extension: .scss
Sunday, 14 April 13
The scss file
61resources/sass/app.scss
Sunday, 14 April 13
Compass Variables
62
touch/resources/
themes/
stylesheets/
sencha-touch/
default/
_variables.scss
Sunday, 14 April 13
Compass Mixins
63
Sunday, 14 April 13
Quick Tips
•Well documented on http://docs.sencha.com
•Sencha Command
•Sencha Architect 2
•Keep your views clean, use controllers!
•Mobile devices have limited hardware
64
Sunday, 14 April 13
Need another look?
65
http://www.github.com/
Martin1982/
iOSOnRailsConf
Sunday, 14 April 13
66
Sencha Touch by Sencha
Sunday, 14 April 13
66
Sencha Touch by Sencha
Sunday, 14 April 13
Tomorrow’s mini Workshop
67
Prepare to tag along:
Sencha Cmd
Sencha Touch 2.1.1 GPL
Sunday, 14 April 13
QUESTIONS
68
Sunday, 14 April 13
mdkeijzer@ibuildings.nl
@Martin1982
Thank you for listening
Sunday, 14 April 13

More Related Content

PDF
Native Javascript apps with PhoneGap
PDF
Native Javascript apps with PhoneGap 11-04-2014 Codemotion Rome
PDF
Ineditus
PDF
Mobile web apps with sencha touch 2
PPTX
Sencha touch 介紹
PDF
Hybrid Mobile Web Apps with Sencha Touch 2
KEY
2012 09-04 smart devcon - sencha touch 2
PDF
Sencha touch 2
Native Javascript apps with PhoneGap
Native Javascript apps with PhoneGap 11-04-2014 Codemotion Rome
Ineditus
Mobile web apps with sencha touch 2
Sencha touch 介紹
Hybrid Mobile Web Apps with Sencha Touch 2
2012 09-04 smart devcon - sencha touch 2
Sencha touch 2

Similar to Hybrid Mobile Web Apps with Sencha Touch 2 (20)

PDF
Sencha Touch for the Mobile Web
PDF
An Introduction to Sencha Touch
PPTX
Sencha Touch Intro - Toronto HTML5 User Group
PDF
Sencha Touch In Action Jesus Garcia Anthony De Moss Mitchell Simoens
KEY
Creating cross-platform mobile apps
PDF
Native Javascript apps with PhoneGap
PDF
Sencha Touch for Rubyists
PDF
Building Cross Platform Mobile Web Apps
PPT
Sencha touch
PDF
Building cross platform mobile web apps
PDF
Introduction to PhoneGap and PhoneGap Build
PDF
PhoneGap in a Day
PDF
Sencha Touch beta — Amazing Mobile Web Apps with HTML5, CSS3 & JavaScript
PPTX
Mobile native-hacks
PDF
Mobile Web to Mobile Apps
PDF
ModUX keynote
PPTX
Rich mobile apps with sencha touch - intro to sencha
PDF
HTML5 and the dawn of rich mobile web applications pt 1
PDF
Frank Mainzer & Silviu Durduc - Developing mobile app using Sencha Touch
PPTX
An overview of mobile html + java script frameworks
Sencha Touch for the Mobile Web
An Introduction to Sencha Touch
Sencha Touch Intro - Toronto HTML5 User Group
Sencha Touch In Action Jesus Garcia Anthony De Moss Mitchell Simoens
Creating cross-platform mobile apps
Native Javascript apps with PhoneGap
Sencha Touch for Rubyists
Building Cross Platform Mobile Web Apps
Sencha touch
Building cross platform mobile web apps
Introduction to PhoneGap and PhoneGap Build
PhoneGap in a Day
Sencha Touch beta — Amazing Mobile Web Apps with HTML5, CSS3 & JavaScript
Mobile native-hacks
Mobile Web to Mobile Apps
ModUX keynote
Rich mobile apps with sencha touch - intro to sencha
HTML5 and the dawn of rich mobile web applications pt 1
Frank Mainzer & Silviu Durduc - Developing mobile app using Sencha Touch
An overview of mobile html + java script frameworks
Ad

Recently uploaded (20)

PDF
Advanced methodologies resolving dimensionality complications for autism neur...
PDF
Accuracy of neural networks in brain wave diagnosis of schizophrenia
PPTX
Group 1 Presentation -Planning and Decision Making .pptx
PDF
Blue Purple Modern Animated Computer Science Presentation.pdf.pdf
PPTX
20250228 LYD VKU AI Blended-Learning.pptx
PPTX
Digital-Transformation-Roadmap-for-Companies.pptx
PDF
A comparative analysis of optical character recognition models for extracting...
PPTX
KOM of Painting work and Equipment Insulation REV00 update 25-dec.pptx
PDF
Unlocking AI with Model Context Protocol (MCP)
PDF
Reach Out and Touch Someone: Haptics and Empathic Computing
PPTX
Programs and apps: productivity, graphics, security and other tools
PPTX
Machine Learning_overview_presentation.pptx
PDF
Network Security Unit 5.pdf for BCA BBA.
PPT
Teaching material agriculture food technology
PPTX
Spectroscopy.pptx food analysis technology
PPTX
SOPHOS-XG Firewall Administrator PPT.pptx
PDF
Machine learning based COVID-19 study performance prediction
PDF
Assigned Numbers - 2025 - Bluetooth® Document
PDF
TokAI - TikTok AI Agent : The First AI Application That Analyzes 10,000+ Vira...
PPTX
Tartificialntelligence_presentation.pptx
Advanced methodologies resolving dimensionality complications for autism neur...
Accuracy of neural networks in brain wave diagnosis of schizophrenia
Group 1 Presentation -Planning and Decision Making .pptx
Blue Purple Modern Animated Computer Science Presentation.pdf.pdf
20250228 LYD VKU AI Blended-Learning.pptx
Digital-Transformation-Roadmap-for-Companies.pptx
A comparative analysis of optical character recognition models for extracting...
KOM of Painting work and Equipment Insulation REV00 update 25-dec.pptx
Unlocking AI with Model Context Protocol (MCP)
Reach Out and Touch Someone: Haptics and Empathic Computing
Programs and apps: productivity, graphics, security and other tools
Machine Learning_overview_presentation.pptx
Network Security Unit 5.pdf for BCA BBA.
Teaching material agriculture food technology
Spectroscopy.pptx food analysis technology
SOPHOS-XG Firewall Administrator PPT.pptx
Machine learning based COVID-19 study performance prediction
Assigned Numbers - 2025 - Bluetooth® Document
TokAI - TikTok AI Agent : The First AI Application That Analyzes 10,000+ Vira...
Tartificialntelligence_presentation.pptx
Ad

Hybrid Mobile Web Apps with Sencha Touch 2