Introduction to
ionic Framework
data:image/s3,"s3://crabby-images/71310/713102e6a919a2023003e6b4858a0ea0408eb995" alt=""
Hybrid Mobile Apps
-
Platform independent(iOS, Android, WP, ...)
-
HTML5, CSS3, JS
-
Performance Limitations
-
Rapid Development
-
Directly accessing to native API
data:image/s3,"s3://crabby-images/4926d/4926d545d882ab6c9e48be1aef61db9abc0c3d0b" alt=""
Hybrid Mobile Apps
data:image/s3,"s3://crabby-images/4926d/4926d545d882ab6c9e48be1aef61db9abc0c3d0b" alt=""
data:image/s3,"s3://crabby-images/3f3a5/3f3a5fd489117f5d41a92e91d6ff88bc79de1442" alt=""
Hybrid vs. Native
- Use Objective-C, Java etc.
- Best Performance
- Hardware interactive
data:image/s3,"s3://crabby-images/4926d/4926d545d882ab6c9e48be1aef61db9abc0c3d0b" alt=""
- Use HTML/CSS/JS
- Rapid Development
- Easy to customize UI
- Cross-Platform
- Cross-Browser
- Only run on browser
- No hardware interactive
-
Not so fast development
- Hard to customize UI
- Run only one platform
ionic Framework
- An open source framework for developing hybrid mobile apps with Angular, Sass and Cordova
- Contains a lot of mobile-optimized HTML, CSS and JS components
- Good friend with AngularJS to power-up mobile app
- Uses Cordova to create, build, run and deploy mobile apps
data:image/s3,"s3://crabby-images/4926d/4926d545d882ab6c9e48be1aef61db9abc0c3d0b" alt=""
data:image/s3,"s3://crabby-images/a66dd/a66ddec071273fafb32a7ad4914e713690471f7a" alt=""
data:image/s3,"s3://crabby-images/5ac18/5ac186ec4cabe8c8fe86f348943115b97d16b1a9" alt=""
ionic Versions
- The first official Ionic release
- v0.9.08-alpha: 2014-11-21
- Latest Version: 1.0.0-rc.0"neodymium-newt"
- Released: 2015-03-05
data:image/s3,"s3://crabby-images/4926d/4926d545d882ab6c9e48be1aef61db9abc0c3d0b" alt=""
Supported Platforms
- iOS 6+
- Android 4+
- WP 8+ (coming)
- Firefox OS (coming)
data:image/s3,"s3://crabby-images/4926d/4926d545d882ab6c9e48be1aef61db9abc0c3d0b" alt=""
The Stack Of Technologies
data:image/s3,"s3://crabby-images/4926d/4926d545d882ab6c9e48be1aef61db9abc0c3d0b" alt=""
ionic Concept
data:image/s3,"s3://crabby-images/4926d/4926d545d882ab6c9e48be1aef61db9abc0c3d0b" alt=""
data:image/s3,"s3://crabby-images/c190e/c190ea9dad84b0ed974be8caa02e22bb171b21ba" alt=""
What Should Know To Start?
data:image/s3,"s3://crabby-images/4926d/4926d545d882ab6c9e48be1aef61db9abc0c3d0b" alt=""
- HTML 5 / CSS 3 / JavaScript
- command line tools
- AngularJS
- Sass (optional)
Prerequisites?
data:image/s3,"s3://crabby-images/4926d/4926d545d882ab6c9e48be1aef61db9abc0c3d0b" alt=""
- Java SDK
- Android SDK + Eclipse/Android Studio
- Node / NPM
- Cordova
- Gulp
- Ionic
Setting Up Development Environment
data:image/s3,"s3://crabby-images/4926d/4926d545d882ab6c9e48be1aef61db9abc0c3d0b" alt=""
$ npm install -g ionic
Install ionic
$ npm install -g cordova
Install Cordova
Create ionic App
data:image/s3,"s3://crabby-images/4926d/4926d545d882ab6c9e48be1aef61db9abc0c3d0b" alt=""
- blank
- tabs
- sideMenu
data:image/s3,"s3://crabby-images/b14c7/b14c7da7cf5b6567d6901eb188c139ccaa567022" alt=""
data:image/s3,"s3://crabby-images/12739/1273925b2c554fbe966aee953f69c7cdd27bc290" alt=""
data:image/s3,"s3://crabby-images/3746e/3746ec35461a842290100dc9077b4038569ce2ac" alt=""
$ionic start myApp <template>
ionic App Folder Structure
data:image/s3,"s3://crabby-images/4926d/4926d545d882ab6c9e48be1aef61db9abc0c3d0b" alt=""
Workflow
data:image/s3,"s3://crabby-images/4926d/4926d545d882ab6c9e48be1aef61db9abc0c3d0b" alt=""
Testing on web server
$ionic serve
Add mobile platform
$ionic platform add [android/ios]
Run test on device/emulator
$ionic [run/emulate] [android/ios]
Ionicons
data:image/s3,"s3://crabby-images/4926d/4926d545d882ab6c9e48be1aef61db9abc0c3d0b" alt=""
Components
data:image/s3,"s3://crabby-images/4926d/4926d545d882ab6c9e48be1aef61db9abc0c3d0b" alt=""
List
Form
Checkbox
Components
data:image/s3,"s3://crabby-images/4926d/4926d545d882ab6c9e48be1aef61db9abc0c3d0b" alt=""
Range
Tabs
Toggle
List Component HTML
data:image/s3,"s3://crabby-images/4926d/4926d545d882ab6c9e48be1aef61db9abc0c3d0b" alt=""
What is Cordova?
data:image/s3,"s3://crabby-images/4926d/4926d545d882ab6c9e48be1aef61db9abc0c3d0b" alt=""
data:image/s3,"s3://crabby-images/51b47/51b47593ee26b8f03d5d884b7b33534b8a72ade7" alt=""
What is Cordova?
data:image/s3,"s3://crabby-images/4926d/4926d545d882ab6c9e48be1aef61db9abc0c3d0b" alt=""
- Apache Cordova is a JavaScript API that "wraps" native APIs
- Create Mobile Apps using HTML/JS/CSS
- Re-use existing "web" skills
- Re-use existing web frameworks
-
The User Interface is effectively a WebView that occupies the complete screen and runs in the native Container.
What is ngCordova?
data:image/s3,"s3://crabby-images/4926d/4926d545d882ab6c9e48be1aef61db9abc0c3d0b" alt=""
data:image/s3,"s3://crabby-images/8bc60/8bc6092a77eeb9ceab5c20cd1978fe88cadb16dd" alt=""
What is ngCordova?
data:image/s3,"s3://crabby-images/4926d/4926d545d882ab6c9e48be1aef61db9abc0c3d0b" alt=""
- Cordova has a lot of available plugins
- Plugins give access to the machine functions
- ngCordova "Angularizes" plugins for ready use
- You are always free to write your own wrapper code
ngCordova Plugins
data:image/s3,"s3://crabby-images/4926d/4926d545d882ab6c9e48be1aef61db9abc0c3d0b" alt=""
Showcase
data:image/s3,"s3://crabby-images/4926d/4926d545d882ab6c9e48be1aef61db9abc0c3d0b" alt=""
Demo...
data:image/s3,"s3://crabby-images/4926d/4926d545d882ab6c9e48be1aef61db9abc0c3d0b" alt=""
Resources
-
ionic Framework
- ngCordova
-
Pluralsight - Building Mobile Apps With the Ionic Framework and AngularJS
-
Cihad HORUZOĞLU - Hybrid Apps with Angular & Ionic Framework @IstanbulCoders
-
Troy MILES - Cross Platform Mobile Apps with the Ionic Framework
-
Huy TRAN - Building mobile app with Ionic Framework
-
Virinchy P - What is Cordova and how does it work ?
-
Raymond CAMDEN - My perspective of working with the Ionic Framework
-
Jeremy Wilken - Ionic in Action - Hybrid Mobile Apps with Ionic and AngularJS
thanks...
Introduction to Ionic Framework
By Barış SÖNMEZ
Introduction to Ionic Framework
An introduction to Ionic Framework.
- 612