The beautiful, open source framework for developing hybrid mobile apps with HTML 5
data:image/s3,"s3://crabby-images/c46ae/c46ae8d22488d9abedc79599ef2bb24afd8d5da9" alt=""
Demo Time
In < 10 minutes
-
Create New Project
-
Pull in some data
-
Deploy to Android Device
"So you want to build a native app?"
@digitaldrummerj
More Platforms. More Problems.
Why are we still coding for multiple platforms?
data:image/s3,"s3://crabby-images/afdca/afdca30585963fa70af2f4e0b98d458648c5d257" alt=""
data:image/s3,"s3://crabby-images/0d85c/0d85c77b2dbd1ff08a733d6af875ef7cd0a1526b" alt=""
data:image/s3,"s3://crabby-images/6af67/6af67fbb2a9bbef491697ddac2c584748035c47b" alt=""
data:image/s3,"s3://crabby-images/7425f/7425fc173ebb03a9798059b033d7c6a8425a6f0b" alt=""
@digitaldrummerj
"Is there an alternative?"
@digitaldrummerj
data:image/s3,"s3://crabby-images/9e03f/9e03f5e2c8e3f49382ab33bb2568d09b3f51d94b" alt=""
"Hello."
"I have heard hybrid apps are slow!"
@digitaldrummerj
Mobile devices have rapidly improved!
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 |
Web Technologies You
Already Know and Love
data:image/s3,"s3://crabby-images/89978/89978ce4c318ec11a820eb0fc3fb4f457d7d7289" alt=""
data:image/s3,"s3://crabby-images/0f652/0f65223424bee6df16cf642d3afc8547c961868b" alt=""
data:image/s3,"s3://crabby-images/927e3/927e3c7fdc487b2a38f190f5f0ed885049900839" alt=""
Standing on the Shoulders of AngularJS
-
Proven for large-scale webapp development
-
Extends the HTML vocabulary
-
UI Components using Directives and Services
data:image/s3,"s3://crabby-images/a0bbc/a0bbcf6708d3f5b128192b59f35a1d2705b439f4" alt=""
@digitaldrummerj
Plain ol' CSS
-
Cohesive visual system
-
Clean and simple
-
Easy to customize
-
Stand-alone CSS
data:image/s3,"s3://crabby-images/1550d/1550d529674287355b8472cd22143f1e3ee2f2ff" alt=""
@digitaldrummerj
-
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/0d7c0/0d7c0d71cc3953758122335eb27e0eab4b26febb" alt=""
@digitaldrummerj
Performance Obsessed
-
Hardware accelerated animations
-
Minimal DOM Manipulation
-
Removed 300ms tap delay
data:image/s3,"s3://crabby-images/8d7ab/8d7ab3f9f2767b5eb5ce027fdb5158d12bf871e8" alt=""
@digitaldrummerj
Native Focused
-
Modeled off of native SDKs
-
Built to work with Cordova
data:image/s3,"s3://crabby-images/b18a5/b18a52addaac11a3fc74ada3243744dca85e743b" alt=""
@digitaldrummerj
@digitaldrummerj
data:image/s3,"s3://crabby-images/80e6e/80e6e09c496d340fdb922fb4d4c3cc326521037d" alt=""
Supported Devices
@digitaldrummerj
data:image/s3,"s3://crabby-images/afdca/afdca30585963fa70af2f4e0b98d458648c5d257" alt=""
data:image/s3,"s3://crabby-images/0d85c/0d85c77b2dbd1ff08a733d6af875ef7cd0a1526b" alt=""
iOS 6+
Android 4+
What about Windows Phone?
@digitaldrummerj
-
Supports ms-appx protocol Cordova uses
-
Improved the click/drag/scrolling behavior.
-
Created a fix for ng-show in IE
-
Removed the IE “squish” effect.
-
Added a fixed range input display
-
Set default spinner to one that animates properly
Future with Windows Phone?
@digitaldrummerj
-
Number of issues around tap, click, activator behavior
-
Ionic is working with some Microsoft team members to address Windows Phone issues more directly.
"How does it all come together?"
But wait...
There is
No
Web SDK
Ionic Built-In UI Elements
i.e. Web SDK
Ionicons
Over 600 MIT licensed font-icons included
data:image/s3,"s3://crabby-images/d1e8e/d1e8e89587125757bb69ffc36b83b0caa31fe1da" alt=""
@digitaldrummerj
List
data:image/s3,"s3://crabby-images/283a7/283a7800223bfcc83fdc026d86c11753bdadffe2" alt=""
<div class="list">
<div class="item item-divider">
Candy Bars
</div>
<a class="item" href="#">
Butterfinger
</a>
<a class="item" href="#">
Kit Kat
</a>
...
</div>
@digitaldrummerj
Complex List
data:image/s3,"s3://crabby-images/b6be4/b6be4414bf6a448480b49ac483a8bce4e4fd7916" alt=""
<ion-list>
<ion-item
ng-repeat="item in items"
class="item-thumbnail-left">
<img ng-src="{{ item.pic }}">
<h2>{{ item.name }}</h2>
<p>{{ item.quote }}</p>
</ion-item>
</ion-list>
@digitaldrummerj
Collection Repeat
data:image/s3,"s3://crabby-images/2f3e0/2f3e05e9f0b5d8db856ce3c322c74a2cddf01cba" alt=""
<ion-list>
<ion-item
collection-repeat="item in contacts"
class="item item-avatar"
item-width="100%">
<img
ng-src="img/{{item.mycat}}.png">
<h2>
{{item.name}}
</h2>
<p> </p>
</ion-item>
</ion-list>
@digitaldrummerj
Tabs
data:image/s3,"s3://crabby-images/72918/72918b7cdf58d5f8c367895f0e5a1c4e95b56be6" alt=""
<ion-tabs class="tabs-icon-only">
<ion-tab title="Home"
icon="ion-star">
<ion-nav-view></ion-nav-view>
</ion-tab>
<ion-tab title="Feedback"
icon="ion-thumbsdown">
<ion-nav-view></ion-nav-view>
</ion-tab>
<ion-tab title="Messages"
icon="ion-chatbubble-working">
<ion-nav-view></ion-nav-view>
</ion-tab>
</ion-tabs>
@digitaldrummerj
Side Menu
data:image/s3,"s3://crabby-images/0ea01/0ea010988876ac5696cc0c7ea3d8f7505a06089d" alt=""
<ion-side-menus>
<ion-side-menu-content>
<ion-nav-bar></ion-nav-bar>
<ion-nav-view></ion-nav-view>
</ion-side-menu-content>
<ion-side-menu side="left">
<header class="bar bar-header bar-positive">
<div class="title">Projects</div>
</header>
<ion-content has-header="true">
<div class="list">
<a href="#/work" class="item">Work</a>
<a href="#/home" class="item">Home</a>
</div>
</ion-content>
</ion-side-menu>
</ion-side-menus>
@digitaldrummerj
Slide Box
data:image/s3,"s3://crabby-images/c2f4a/c2f4a5a880f328cab87c32821780d4662c310a12" alt=""
<ion-slide-box
on-slide-changed="change(index)">
<ion-slide>
Slide 1
</ion-slide>
<ion-slide>
Slide 2
</ion-slide>
<ion-slide>
Slide 3
</ion-slide>
</ion-slide-box>
@digitaldrummerj
Action Sheet
data:image/s3,"s3://crabby-images/b4cc6/b4cc6b4af016260abd61e9e9c7f29ddae044cb18" alt=""
$ionicActionSheet.show({
titleText: 'Modify your album',
buttons: [
{ text: 'Share' },
{ text: 'Move' },
],
destructiveText: 'Delete',
cancelText: 'Cancel',
buttonClicked: function(index) {
console.log('BUTTON CLICKED', index);
return true;
}
});
@digitaldrummerj
Popover
data:image/s3,"s3://crabby-images/8f850/8f850117927b107a7ad53cd74121d3e50043bee4" alt=""
$ionicPopover.fromTemplateUrl('popover.html',
function(popover) {
$scope.popover = popover;
}
);
@digitaldrummerj
<ion-popover-view>
<ion-header-bar>
<h1 class="title">My Popover Title</h1>
</ion-header-bar>
<ion-content class="padding">
Hello!
</ion-content>
</ion-popover-view>
Modal
data:image/s3,"s3://crabby-images/3fa26/3fa26f9e88c1de113ead62cd0cbb64d023f8e3f8" alt=""
$ionicModal.fromTemplateUrl('modal.html', {
scope: $scope
}).then(function(modal) {
$scope.modal = modal;
});
@digitaldrummerj
data:image/s3,"s3://crabby-images/93fb3/93fb3456eaba49f02177bc007d36f9e3516558fd" alt=""
<script id="my-modal.html" type="text/ng-template">
<ion-modal-view>
<ion-header-bar>
<h1 class="title">New Contact</h1>
</ion-header-bar>
<ion-content>
Hello!
</ion-content>
</ion-modal-view>
</script>
Pull to Refresh
data:image/s3,"s3://crabby-images/469b0/469b0b4090c71055ccd37586adfa9e6e4f3ab39d" alt=""
<ion-refresher on-refresh="refreshData()"
pulling-text="Pulling to refresh..."
refreshing-text="Refreshing!"
refreshing-icon="ion-loading-c">
</ion-refresher>
@digitaldrummerj
Navigation
data:image/s3,"s3://crabby-images/8ebb0/8ebb068fe5f42322b24a0c25c7f89126486569ed" alt=""
<ion-nav-bar>
<ion-nav-back-button>
Back
</ion-nav-back-button>
</ion-nav-bar>
<ion-nav-view>
<!-- content -->
</ion-nav-view>
@digitaldrummerj
Are people using it?
Ionic's Adoption
-
over 13, 000+ stars on GitHub
-
Top 50 most popular open source projects
- Ionic CLI averages 2,300 downloads/day
-
400,000+ apps have been started from the CLI
-
Released Alpha: November 2013
-
Released Beta: March 2014
-
Release Candidate: Winter 2014
- 1.0 Release: Spring 2015
@digitaldrummerj
data:image/s3,"s3://crabby-images/02bfb/02bfb6c597f0c240a54dd20a5294e78f645ded09" alt=""
- The personal stylist in your pocket
- Pulls in over 2 million products from 100 big name fashion brands
- Next generation fashion mall for whatever style you require.
- http://mallzee.com/
Mallzee
@digitaldrummerj
data:image/s3,"s3://crabby-images/9c49f/9c49f09a335cfd0a142148a89ec05f8ec8cf1859" alt=""
- Like Uber for commercial trucking
- Connect to thousands of freight shippers and brokerages across the country
- https://www.keychainlogistics.com/
Keychain
@digitaldrummerj
data:image/s3,"s3://crabby-images/bcff8/bcff84d064d82fe0bfcb4f118549f47be8121f29" alt=""
- Fitness app that guides anyone thru 5-60 minute circuits
- Downloaded over 3 million times
- Been featured in multiple Health and Fitness lists within both the App Store and Google Play
- http://sworkit.com/
Sworkit
@digitaldrummerj
How to get started?
! But Not So Fast
$ npm install -g cordova@5.0.0 ionic gulp bower
Installing Ionic
@digitaldrummerj
-
Install NodeJs - http://nodejs.org
-
Install Git (Windows Only) - https://msysgit.github.io/
-
Globally install npm packages:
-
cordova@5.0.0
-
ionic
-
gulp
-
bower
-
Android Prerequisites
-
Windows / Linux / OSx
-
Java SDK 7
-
Android Studio
-
Android SDK (API 19 = 4.4)
-
Google Chrome (for debugging)
-
Genymotion
-
Google Developers Account ($25 lifetime)
@digitaldrummerj
iOS Prerequisites
-
MAC / OSx only
-
XCode
-
iOS Simulator
-
Safari
-
Apple Developers Account ($99 per year)
@digitaldrummerj
Ionic on Windows Setup
-
Automated using Chocolatey:
-
Read the "How To Use this Gist File Section" for instructions
-
Manual:
@digitaldrummerj
Ionic on a Mac Setup
@digitaldrummerj
Ionic on Ubuntu Setup
@digitaldrummerj
What's building an app like?
Create ionic app
Create new project
Test on web browser
Add mobile platform (Android or iOS)
Run test on device/emulator
ionic start myApp [blank/tabs/sideMenu]
ionic serve
ionic platform add [android/ios]
ionic [run/emulate] [ android/ios]
@digitaldrummerj
data:image/s3,"s3://crabby-images/1b395/1b3950655bb3284089487720ca79a969e0d11876" alt=""
Side by Side
Android and iOS Phone
Supports Live Reload
Ionic Lab
$ ionic serve --lab
@digitaldrummerj
Ionic View
Makes it easy to share your Ionic app without ever going through the App Store.
$ ionic start myApp tabs
$ cd myApp
$ ionic upload
$ ionic share [email address]
@digitaldrummerj
data:image/s3,"s3://crabby-images/c1b07/c1b07e621961e615acbf96ec880d88fb0a2201bc" alt=""
Automatically generate icons and splash screens
Creates size needed for each platform
Icons and Splash Screens
$ ionic resources
$ ionic resources --icon
$ ionic resources --splash
@digitaldrummerj
Get Ionic documentation from the Ionic CLI
Opens a browser window directly to the doc
Ionic Docs
$ ionic docs ls
@digitaldrummerj
data:image/s3,"s3://crabby-images/2f027/2f0276af9ea7f038298c000ced0360e24dd08fd2" alt=""
Additional Tooling from Ionic
Ionic Creator
@digitaldrummerj
data:image/s3,"s3://crabby-images/5844c/5844c17c8b70c54eb74a9503094795190db96dde" alt=""
Ionic and Crosswalk
Specify version of Chrome to run your Cordova App.
Up to 10x performance increase
App will grow ~10-15 mb in size.
$ionic start my_app
$cd my_app
$ionic browser add crosswalk
$ionic run android
@digitaldrummerj
Ionic Push
-
Easily send push notifications to
-
Multiple platforms
-
Schedule notifications
-
Target specific user groups
-
-
Intuitive UI as well as a REST API.
@digitaldrummerj
Ionic Deploy
-
Update your Ionic applications without having to resubmit to app stores
-
Rollback to previous versions at any time.
-
Currently in Alpha. Not recommended for production
@digitaldrummerj
Ionic Analytics
-
Track every part of the user’s interaction
-
Easily identify pain points
-
Setup custom events
@digitaldrummerj
Pricing
-
-
Tools and Services are currently in alpha testing
-
Free during this period
-
Billing information and pricing plans will be announced as it gets closer to production.
-
@digitaldrummerj
Demo Time
-
Ionic Creator
-
Ionic Resource
-
Ionic Themes
-
Ionic View
-
Ionic Push
thank you
i'm Justin.
@digitaldrummerj - digitaldrummerj@gmail.com
http://digitaldrummerj.me
1 480 ### ####
data:image/s3,"s3://crabby-images/87769/877697ab5751ad3328092284b150da9b60f6efff" alt=""
Ionic Framework Overview - July 2015
By Justin James
Ionic Framework Overview - July 2015
Presentation for an Ionic Framwork Overview. Learn what the Ionic Framework is, what is provides, and how to start using it.
- 3,303