data:image/s3,"s3://crabby-images/14c30/14c30692bfc968249ec793bb45a37f8b92e6f1e3" alt=""
Hybrid mobile apps with AngularJS and Ionic
CONTENTS AT A GLANCE
1. Hybrid vs Native
2. Ionic Framework overview
3. UI Elements
4. The CLI
5. The future
6. probably a DEMO...probably
"Cool...let's go native!"
Downsides of native
- knowledge of each platform
- separate code bases, virtually not reusable
- different hardware (except for Android)
- generally high development costs
More Platforms. More Problems.
data:image/s3,"s3://crabby-images/1feb2/1feb2926eebc523ba3d065aa805d59a4aaec4897" alt=""
data:image/s3,"s3://crabby-images/997cd/997cd01d277230c0fc04f8e5c4cb7b424a67555b" alt=""
data:image/s3,"s3://crabby-images/9b6a6/9b6a657d029a917ea27b83e8a111e4e197405f5a" alt=""
data:image/s3,"s3://crabby-images/74602/746024959cd656a90601f4eab1c5df26c5d198ed" alt=""
So, what's the alternative?
data:image/s3,"s3://crabby-images/7aefa/7aefa4424e0acfed92e3132fc9fe6041d307846c" alt=""
- Hybrid Apps: HTML5 that acts like native
- Cordova - the engine that powers Phonegap
- Web wrapped in native layer
- Direct access to native APIs
- Familiar web dev environment
- Develop a single code base (web platform)
What's that, Zack?
What's that, Zack?
data:image/s3,"s3://crabby-images/b11c0/b11c0e44d8a9b30048e949f63dcab170f116cef8" alt=""
http://techcrunch.com/2012/09/11/mark-zuckerberg-our-biggest-mistake-with-mobile-was-betting-too-much-on-html5/
You're (probably) not building Facebook
OK, native SDKs are kinda cool
- Built in UI components
- Views
- Navigation and stack history
- Transitions
- Gestures
"Hybrid apps are sooo slooow"
Your hybrid app is so slow that when it tried to cross the road it got a parking ticket
data:image/s3,"s3://crabby-images/3e114/3e114af44dcec843a6f8e57061071a77b660f26a" alt=""
Hybrid mobile apps...
True, BUT...
...times are changing, mobile devices are rapidly evolving
Year | Device | Processor | RAM |
---|---|---|---|
2007 | iPhone | 620 MHz | 128 MB |
2010 | iPhone 4 | 1 GHz | 512 MB |
2015 | iPhone 6 | 1.4 GHz dual-core | 1 GB |
https://mixpanel.com/trends/#report/ios_8/from_date:-209,report_unit:day,to_date:0
data:image/s3,"s3://crabby-images/b0a05/b0a05fca4ccd94279e9d0b58fac608a4206a760d" alt=""
https://mixpanel.com/trends/#report/android_os_adoption/from_date:-364,to_date:1
data:image/s3,"s3://crabby-images/44ff7/44ff78eb17a7fd85ed9d0c615495ef1b01b54697" alt=""
There's No Web SDK
- We need to bridge the gap between web and native
- We need rich, native-style UI components and interactions
- We need UI APIs, not just jQuery widgets
Say hello to my little friend
data:image/s3,"s3://crabby-images/c12f1/c12f15e00ab3086988cd75135e0f82b9c2537015" alt=""
Web Technologies You Already Know and Love
data:image/s3,"s3://crabby-images/cc5da/cc5da47552f8d5fae55f741a9cda2bfb722e11d3" alt=""
data:image/s3,"s3://crabby-images/f2de9/f2de951f5e6ea10e50cbf485f6df4ced3f19bf96" alt=""
data:image/s3,"s3://crabby-images/c8081/c8081ea840daa855aa4e27744e4cf5ccf795114f" alt=""
Web Technologies You Already Know and Love
data:image/s3,"s3://crabby-images/cc5da/cc5da47552f8d5fae55f741a9cda2bfb722e11d3" alt=""
data:image/s3,"s3://crabby-images/f2de9/f2de951f5e6ea10e50cbf485f6df4ced3f19bf96" alt=""
data:image/s3,"s3://crabby-images/c8081/c8081ea840daa855aa4e27744e4cf5ccf795114f" alt=""
Native focused
data:image/s3,"s3://crabby-images/68a32/68a32e8bd984fa1d29662897f61380afda106ac2" alt=""
- Modeled off of native SDKs
- Built to work with Cordova
Performance Obsessed
- Hardware accelerated animations
- Minimal DOM Manipulation
- Remove 300ms tap delay
data:image/s3,"s3://crabby-images/fd179/fd17917b6649362aa680b2173893e9ccbe447494" alt=""
- CSS generated from the Sass preprocessor
- Quickly give your app its own look and feel
- CSS designed to be easily overridden
- Variables based with default settings
- 80+ reusable and useful mixins
data:image/s3,"s3://crabby-images/a5cd8/a5cd8e96df9421f7b16a84fddb40bb71a459bd53" alt=""
Built in font-icons set - Ionicons
data:image/s3,"s3://crabby-images/6dd02/6dd02c9580903237312eb63d988a6f286346b4e7" alt=""
Ionic Adoption
- 13,000+ Github Stars
- Top 50 most starred Github repos
- Consistently Top 10 trending JS Github repos
- Ionic CLI averages 2,300 downloads/day
- 400,000+ Ionic apps have been started from our CLI
- Released Alpha: November 2013
- Released Beta: March 2014
- Release Candidate: Winter 2015
But how does it work?
Your app
Ionic
AngularJS
Cordova (WebView)
Native Wrapper (SDK)
Show me some code!
Ionic UI components
Lists
<ion-content>
<ion-list>
<ion-item ng-repeat="item in items">
Item {{ item.id }}
<!-- delete -->
<ion-delete-button class="ion-minus-circled"
ng-click="onItemDelete(item)">
</ion-delete-button>
<!-- Option buttons -->
<ion-option-button class="button-assertive">
Edit
</ion-option-button>
<ion-option-button class="button-calm">
Share
</ion-option-button>
<!-- reorder -->
<ion-reorder-button class="ion-navicon"
on-reorder="moveItem(item,$fromIndex,$toIndex)">
</ion-reorder-button>
</ion-item>
</ion-list>
</ion-content>
data:image/s3,"s3://crabby-images/424e2/424e2fec673379a4e54ff8adb4fbb318ff8850f3" alt=""
Navigation and Tabs
<ion-tabs>
<ion-tab title="Home" icon="ion-home">
<ion-nav-view name="home"></ion-nav-view>
</ion-tab>
<ion-tab title="About" icon="ion-information">
<ion-nav-view name="about"></ion-nav-view>
</ion-tab>
<ion-tab title="Contact" icon="ion-ios7-world">
<ion-nav-view name="contact"></ion-nav-view>
</ion-tab>
</ion-tabs>
data:image/s3,"s3://crabby-images/424e2/424e2fec673379a4e54ff8adb4fbb318ff8850f3" alt=""
- Uses AngularUI Router
- Transitions follow direction of nav
- Nested views
- Each tab has its own nav history
Side menu
<ion-side-menu-content>
<ion-nav-view name="menuContent"></ion-nav-view>
</ion-side-menu-content>
<ion-side-menu side="left">
<ion-header-bar class="bar-assertive">
<h1 class="title">Left Menu</h1>
</ion-header-bar>
<ion-content>
...
</ion-content>
</ion-side-menu>
</ion-side-menus>
data:image/s3,"s3://crabby-images/424e2/424e2fec673379a4e54ff8adb4fbb318ff8850f3" alt=""
Modals
$ionicModal.fromTemplateUrl('modal.html', {
scope: $scope
}).then(function(modal) {
$scope.modal = modal;
});
data:image/s3,"s3://crabby-images/424e2/424e2fec673379a4e54ff8adb4fbb318ff8850f3" alt=""
- AngularJS Service
- Inline or external template
Other cool stuff worth mentioning
- Platform continuity
- Swipe to go back
- Cached views
- Automatic splash and icon generator
- collection-repeat (ng-repeat on steroids)
Other cool stuff worth mentioning
data:image/s3,"s3://crabby-images/36a5b/36a5b894e82ea93a9a438a7118b3441c1a604585" alt=""
data:image/s3,"s3://crabby-images/3b413/3b413cd40c5df793043f97faac8ccbc5a397d364" alt=""
Ionic Creator
Ionic View mobile app
Ionic CLI
- Quickly create a project with starter templates
- Boilerplate app structure ready for customization
- Preconfigured tools: Gulp, Sass, Bower, etc.
- Start a local dev server with LiveReload
- Update Ionic Framework library files
- Build and run native apps
Creating a project, as easy as...
- $ npm install -g ionic cordova
- $ ionic start myapp sidemenu
- $ cd myapp
- $ ionic serve
The future
data:image/s3,"s3://crabby-images/5791e/5791ef7617a3af6c2ed323be45b11cd42c9ac057" alt=""
Alternatives worth mentioning
data:image/s3,"s3://crabby-images/e4e9d/e4e9d097c0146e872bef88942a1b6a6dc55929c8" alt=""
data:image/s3,"s3://crabby-images/91529/915291486e0cb6c607f9afc5b4b2d2081df4b6ef" alt=""
data:image/s3,"s3://crabby-images/17644/17644f0440c15ecae913892f5bd6e95849f31dbb" alt=""
data:image/s3,"s3://crabby-images/fa8c0/fa8c0dc54283470207d757a16c8532f01b92aacc" alt=""
data:image/s3,"s3://crabby-images/e5248/e524873e63bc2ba291523602635b7fd249d6baae" alt=""
Last but not least...
data:image/s3,"s3://crabby-images/f8a1c/f8a1ccc5094bb2e808c99a42d7ba8d24144af502" alt=""
DEMO TIME, as promised :)
Angular meetup
By Andrei Antal
Angular meetup
- 1,307