Ionic + AngularJS

Ionic Framework

Ionic framework is the youngest in our top 5 stack, as the alpha was released in late November 2013. Built on top of the popular AngularJS framework from Google, Ionic utilizes AngularJS to provide the application structure, while Ionic itself focuses on the user interface. In other words, we see a match between the power of Angular and the beauty of Ionic UI.

Ionic provides a set of Angular directives (custom HTML elements) for it’s own components, making it as easy to use the widgets as writing a line of HTML code. In addition to directives, Ionic uses Angular’s touch recognizers, view animation logic, HTML sanitation, and asynchronous communication.

While you can use Ionic straight after cloning or unpacking the library zip, you can also install their Node.js-based CLI through NPM and start quickly with their seed project.

Even though Angular is currently the Ionic’s workhorse, the developers are keeping their (and ours) options open with plans to support other frameworks such as Knockout or EmberJS. This particular review is strongly influenced by AngularJS and it doesn’t vouch for the accuracy with other frameworks when Ionic support emerges.

MV* Pattern

Angular JS used to be an MVC framework, but over time it became closer to MVVM where the $scope object acts as a ViewModel, manipulated through a Controller function. With such a flexible approach developers can use MVC or MVVM per their liking, as long as the goal is achieved: separating presentation from business logic while boosting maintainability and productivity.

Class System

Neither Angular JS or Ionic are object oriented JavaScript frameworks so they don’t make use of a class system. This can (but shouldn’t) be observed as a weakness or a strength, depending on the level of simplicity requested on the JavaScript front end.

DOM control

Angular embeds jqLite, a fraction of jQuery that allows DOM manipulation in a cross-browser compatible manner, leaving a very small footprint. For extended functionality, jQuery can be loaded with the document.

UI and Theming

When it comes to UI, Ionic shows its potential. Ionic’s true beauty is its simplicity. In almost Google-like (but not Android-like) style it uses the existing HTML5 and CSS3 capabilities to deliver fast experiences. The speed is exactly in its simplicity – no unnecessary shadows, rounded corners, gradients but just flat, clean simple, powerful, unadulterated HTML5. Ionic doesn’t promise you native-looking UI, but it does deliver very fast and consistent interface, even on the devices you considered to be slow with rendering HTML5 apps.

Customizable through SASS, Ionic comes with handy variables and mixins to extend for customized appearance. Additionally, it’s packaged with its own open sourced icon library featuring over 440 icons to chose from.

Widgets

Ionic’s components are powerfully simple. They are custom HTML elements, as per Angular directive principles, but Ionic also provides Controllers to complement configuration and interaction. While some frameworks may provide more complex widgets, Ionic offers somewhat simpler building blocks that can be combined to deliver rich user interfaces. As of alpha version, the framework provides with a plethora of form elements, header and footer bars, buttons, a simple list with customizable items, grid elements, and more.

Responsive Design (RWD)

Internally, Ionic leverages Responsive Web Design principles to yield optimized experience such as based on screen size or pixel density. Any app-specific RWD scenarios are welcome and will play very nicely with Ionic.

Desktop support

Meant for hybrid mobile applications (installable on a mobile device through an app store), Ionic is not meant to be be used for desktop web apps/sites. While the content will be displayed nicely, it will be optimized for its intended purpose. Those wishing to create apps that fit both environments can stay with Angular JS, but use Zurb Foundation, Twitter Bootstrap or similar UI library.

Third party plugins

No third party plugins or extensions are available at the moment.

Extensibility

Much of extensibility in Ionic will come either from (S)CSS or creating Angular directives and controllers. That makes extensibility an integral part of application development – unavoidable, but not demanding at all. Even the developers new at Ionic and Angular won’t struggle.

Building tools

Grunt is used for building Ionic making that #1 JavaScript building tool that much more attractive for your project’s purposes.

Packaging (native)

Ionic apps will require external tools for packaging purposes. It is tested to work with PhoneGap, Cordova, and Trigger.io.

Device API

Ionic does not support device APIs.

Documentation

Ionic’s documentation is decently complete considering the alpha stage of the framework. Example rich, the docs show a preview of what most of components will do on a mobile device. And the preview is very attractive, too.

Angular’s documentation will satisfy beginner developers, but may soon become insufficient. As the appetites for information grow to expert levels, developers may be forced to resort to the source code or elsewhere.

License

Both Ionic and AngularJS are available under the MIT license.

Community

Since it’s in a very early stage of life, Ionic still doesn’t have a mature community. However, given the same circumstance, its popularity is raising faster than for many other (and older) frameworks.

What would they say?

JavaScript developer:
A refreshing and straight forward way of building rich apps no matter the size. The MVC and MVVM patterns are done cum grano salis,
as the old latin would say had they had the opportunity to work with
Angular JS. Additionally, as views are defined using HTML and data
models as simple as plain JavaScript objects, the developers will easily
end up writing less code and use less of the expensive time to produce
high quality apps.

Designer:
Passionate designers will love Ionic as it allows them to customize the
layout to their liking, without having to modify someone else’s
complicated widgets and potentially break the app’s functionality.
Customizing the UI may remind of working with Zurb Foundation or Twitter
Bootstrap.

Product manager:
The initial barrier to get started with AngularJS is very low, without
needing to know the entire framework in order to build an easy app.
However, beginners faced with more advanced tasks in a complex
application will face an increasingly steep learning curve. Also,
Angular is built with testing in mind. Make use of it early in the game.

Keep in mind that Ionic is meant to be used for hybrid apps and not mobile websites.

时间: 2024-08-29 09:19:29

Ionic + AngularJS的相关文章

【Ionic+AngularJS 开发】之『个人日常管理』App(一)

写在前面的话 过去一年自己接触了不少手机前端开发,得益于现在手机性能的提升和4G普及,感觉使用混合技术开发手机App已经可以满足越来越多的应用场景了.新年伊始,对自己2016年所学知识做一个阶段性总结,记录一个自制的"小而萌"Hybrid App开发历程,共勉! [扩展阅读] 企业移动应用开发 混合开发成香饽饽 2016年JavaScript领域中最受欢迎的"明星"们 Hybrid APP混合开发的一些经验和总结 App预览 (*模糊化的个人数据) 简介 个人日常管

【Ionic+AngularJS 开发】之『个人日常管理』App(二)

准备工作 资源 预装工具 安装bower 1 npm install -g bower 安装ngCordova 1 bower install ngCordova (*由于网络获取资源的原因,后面几次建项目后都无法下载到,自己便复制了原来的ngCordova目录(到YourProject\wwww\lib目录下),发现也是可以使用的) 下载好后,在项目的index.hmtl进行引用: 1 <script src="lib/ngCordova/dist/ng-cordova.js"

Ionic+AngularJS 开发的页面在微信公众号下显示不出来原因查究

ionic 页面 微信浏览器遇到的坑 公司的微信公众号一部分页面是用AngularJS+Ioinc开发,发现在本地浏览器测试的时候都没问题,传到服务器在微信公众号下跑就出问题来,经查是: index-tab页面 406 not accessable http请求头问题 1 $httpProvider.interceptors.push(function() { 2 return { 3 "request": function(config) { 4 //console.log(conf

WebApp开发框架Ionic+AngularJS+Cordova

目前的手机APP有三类:原生APP.WebAPP.HybridApp:HybridApp结合了前两类APP各自的优点,越来越流行. Ionic Ionic是一个新的.可以使用HTML5构建混合移动应用的用户界面框架,它自称为是“本地与HTML5的结合”.该框架提供了很多基本的移动用户界面范例,例如像列表(lists).标签页栏(tabbars)和触发开关(toggleswitches)这样的简单条目.它还提供了更加复杂的可视化布局示例,例如在下面显示内容的滑出式菜单. Ionic宣称他们极度强调

[转]Ionic + AngularJS angular-translate 国际化本地化解决方案

本文转自:http://www.cnblogs.com/maoyazhi/p/4332362.html 欢迎访问我们的网站,网站上有更多关于技术性的交流:http://www.ncloud.hk/技术分享/ionic-plus-angularjs-angular-translate-国际化本地化解决方案/ 一.手动切换语言 1.在app.js文件中首先要加上一个参数: ? 1 angular.module(’passbox’,[‘ionic’,’pascalprecht.translate’])

使用cordova+Ionic+AngularJs进行Hybird App开发的环境搭建手册

一,所需工具 1,JDK:生成 2,安卓SDK开发环境 3,NodeJs:主要使用的还是npm 4,Python开发环境 5,VS 2012(2008,2015也可以,已亲测):安装这个主要是需要一些.net的东西,也没具体查是啥,图个省事. 6,cordova:起到一个移动中间件的作用,负责JS跟原生的一些交互. 7,Ionic 二,说说安装过程中的一些坑 1,JDK问题 建议选用1.7以上的版本,我们使用的是1.8的版本. 2,SDK问题 因为最后构建APP的时候,使用Ionic命令会调用到

ionic+angularJS+cordova(FileTransfer)上传图片

[功能介绍] 在开发应用的时候,经常会遇到需要上传图片的功能,比如修改个人资料的头像.本文介绍的是基于ionic框架,在移动端上传图片的功能. [功能流程] (1)点击页面上的头像,弹出一个对话框,选择[拍照]或者[从相册选择]: (2)选取/拍摄照片: (3)上传照片: [html核心代码] <div ng-controller="myCtrl"> <a ng-click="choosePicMenu()"> <img ng-src=

mac下 搭建Cordova+ionic+AngularJs开发环境

一.下载安装node.js 二.安装cordova和ionic sudo npm install -g cordova ionic 三.创建项目 ionic start ionApp blank 四.打包 $ ionic platform add ios

使用cordova+Ionic+AngularJs进行Hybird App开发的环境搭建手冊

一.所需工具 1,JDK:生成 2.安卓SDK开发环境 3,NodeJs:主要使用的还是npm 4,Python开发环境 5.VS 2012(2008,2015也能够,已亲測):安装这个主要是须要一些.net的东西,也没详细查是啥.图个省事. 6,cordova:起到一个移动中间件的作用.负责JS跟原生的一些交互. 7,Ionic 二,说说安装过程中的一些坑 1,JDK问题 建议选用1.7以上的版本号,我们使用的是1.8的版本号. 2.SDK问题 由于最后构建APP的时候,使用Ionic命令会调