`
rensanning
  • 浏览: 3552668 次
  • 性别: Icon_minigender_1
  • 来自: 大连
博客专栏
Efef1dba-f7dd-3931-8a61-8e1c76c3e39f
使用Titanium Mo...
浏览量:38217
Bbab2146-6e1d-3c50-acd6-c8bae29e307d
Cordova 3.x入门...
浏览量:607608
C08766e7-8a33-3f9b-9155-654af05c3484
常用Java开源Libra...
浏览量:682788
77063fb3-0ee7-3bfa-9c72-2a0234ebf83e
搭建 CentOS 6 服...
浏览量:89535
E40e5e76-1f3b-398e-b6a6-dc9cfbb38156
Spring Boot 入...
浏览量:402152
Abe39461-b089-344f-99fa-cdfbddea0e18
基于Spring Secu...
浏览量:69760
66a41a70-fdf0-3dc9-aa31-19b7e8b24672
MQTT入门
浏览量:91835
社区版块
存档分类
最新评论

Cordova 3.x 基础(10) -- UI框架Ionic Framework

阅读更多
Ionic是DriftyCodiqa(基于 Web 的 jQuery Mobile构建工具)和Jetstrap(基于 Web 的 Twitter Bootstrap 构建工具)之后的第三个项目。面向使用HTML5开发混合式应用的的前端UI开源框架。

http://ionicframework.com/

Demos http://codepen.io/ionic/public-list
Showcase http://showcase.ionicframework.com/
Forum http://forum.ionicframework.com/
Documentation http://ionicframework.com/docs/
Learn Ionic http://learn.ionicframework.com/
Ionic Crash Course https://www.youtube.com/watch?v=C-UwOWB9Io4
Ionic Tutorial http://ccoenraets.github.io/ionic-tutorial/
Structure of an Ionic App http://mcgivery.com/structure-of-an-ionic-app/

Book:
Manning: Ionic in Action

ngCordova:Cordova API的AngularJS 扩展
Ionicons:免费的icon font
Ionic Creator:在线可视化工具

https://github.com/ecofic/ngCordovaMocks:ngCordovaMocks
https://github.com/driftyco/ionic-cordova-android-vagrant:Ionic Cordova Android Vagrant

官方Blog上推荐的Built with Ionic应用:

目前版本发布的速度很快,具体可以参考https://github.com/driftyco/ionic/blob/master/CHANGELOG.md

需要注意的是:
  • 目前还是Beta版
  • 面向Hybrid Mobile App而不是Mobile Web App
  • 只支持iOS 6+ / Android 4+
和jQuery Mobile不同的是Ionic只关注的是UI部分,类似的还有Twitter Bootstrap, Foundation, Ratchet, Topcoat 等。可以看看官方对框架的解释:Where does the Ionic Framework fit in?。熟悉Bootstrap的还可以试试基于Angularjs和Bootstrap 3的 Mobile Angular UI with Bootstrap 3

来源:http://coenraets.org

  • 采用Sass/Gulp、基于AngularJS、零jQuery、最小化DOM操作
  • 非常棒的性能、漂亮的界面设计、详细的文档、活跃的社区
Ionic提供了很多Directive指令(使用JavaScript来实现语义化标签,类似于jsp的taglib)实现丰富的UI控件、大量的常用icon (Icon Pack)、使用AngularUI Router模块来记录页面路由、采用Hammer.js做多点触控、通过AngularJS的扩展做UI交互、左右滑动菜单、下拉更新、自定义主题(核心CSS基于Sass).......。官方网站也提供了很详细的使用说明。

安装ionic
引用
$ npm install -g cordova gulp ionic


新建项目
引用
$ ionic start myApp blank  新建一个空白页面
$ ionic start myApp tabs  新建一个带底部标签的页面
$ ionic start myApp sidemenu 新建一个带侧边栏的页面


运行项目
引用
$ cd MyApp
$ ionic platform add ios
$ ionic build ios
$ ionic emulate ios


另外项目用到gulp来做自动化项目构建。

其中start一个项目的时候是从github上下载seed工程后展开使用,所以也可以通过Cordova CLI创建一个工程后删除www文件夹,从github上下载seed工程后解压覆盖www文件夹即可。


也可以从http://code.ionicframework.com/手动下载。


--> 2014/05/19
安装或更新时候的错误:


①提示以下错误是因为没有安装Python:
引用
gyp ERR! configure error
gyp ERR! stack Error: Can't find Python executable "python", you can set the PYTHON env variable.
gyp ERR! stack     at failNoPython (C:\Program Files\nodejs\node_modules\npm\node_modules\node-gyp\lib\configure.js:113:14)
gyp ERR! stack     at C:\Program Files\nodejs\node_modules\npm\node_modules\node-gyp\lib\configure.js:81:11
gyp ERR! stack     at Object.oncomplete (fs.js:107:15)


②如果安装的是python3比如python-3.4.0,会提示以下错误,安装python-2.7.6就OK啦。
引用
gyp ERR! configure error
gyp ERR! stack Error: Python executable "python" is v3.4.0, which is not supported by gyp.
gyp ERR! stack You can pass the --python switch to point to Python >= v2.5.0 & < 3.0.0.
gyp ERR! stack     at failPythonVersion (C:\Program Files\nodejs\node_modules\npm\node_modules\node-gyp\lib\configure.js:118:14)
gyp ERR! stack     at C:\Program Files\nodejs\node_modules\npm\node_modules\node-gyp\lib\configure.js:107:9
gyp ERR! stack     at ChildProcess.exithandler (child_process.js:635:7)
gyp ERR! stack     at ChildProcess.EventEmitter.emit (events.js:98:17)
gyp ERR! stack     at maybeClose (child_process.js:735:16)
gyp ERR! stack     at Process.ChildProcess._handle.onexit (child_process.js:802:5)


【原因】
查看了一下CLI的源代码,ionic引入了vinyl-fs的依赖,用于npm\node_modules\ionic\lib\ionic\serve.js中,vinyl-fs的vfs.watch('www/**/*'),而它又有子依赖:vinyl-fs@0.1.4 -> glob-watcher@0.0.6 -> gaze@0.6.4。gaze的源码是C++的,需要做本地编译,node-gyp是Node.js本地代码编译构建工具,查看它的安装说明,需要Python2不支持Python3,还需要Visual Studio C++的支持。再查看ionic-cli的修改历史记录,发现是为了支持Livereload才引入了vinyl-fs。

本地测试:

(1)启动Python
进入工程的www文件夹,执行“python -m SimpleHTTPServer 8000”后,在Chrome或Safari中输入“http://localhost:8000”就可以测试了。

(2)启动Gulp
项目用到gulp来做自动化项目构建

修改gulpfile.js
var gulp = require('gulp'),
  connect = require('gulp-connect');

gulp.task('connect', function() {
  connect.server({
    root: 'www',
    livereload: true
  });
});

gulp.task('html', function () {
  gulp.src('./www/*.html').pipe(connect.reload());
});

gulp.task('watch', function () {
  gulp.watch(['./www/*.html'], ['html']);
});

gulp.task('default', ['connect', 'watch']);


引用
$ cd myApp
$ npm install -g gulp
$ npm install
$ gulp

访问: http://localhost:8080

(3)其他HTTP server
还有很多其他的Simple HTTP server,比如:http-server 就是一个NodeJS 下很好用的HTTP Server
引用
npm install http-server -g


基本使用:
<!DOCTYPE html>
<html>
  <head>
    <meta charset="utf-8">
    <meta name="viewport" content="width=device-width, initial-scale=1, maximum-scale=1, user-scalable=no">
    <!-- Ionic的CSS -->
    <link href="lib/ionic/css/ionic.css" rel="stylesheet">
    <!-- 包含了Ionic核心JS、AngularJS、Ionic的AngularJS扩展、ngAnimate/ngSanitize/ui.router模块 -->
    <script src="lib/ionic/js/ionic.bundle.js"></script>
    <SCRIPT LANGUAGE="JavaScript">
    <!--
      // 创建一个AngularJS模块并告诉Angular初期化它
      angular.module('starter', ['ionic']);
    //-->
    </SCRIPT>
  </head>
  <body ng-app="starter">
    <ion-header-bar class="bar-positive">
      <h1 class="title">header</h1>
    </ion-header-bar>
    <ion-content padding="true">
      <h1>Hello wrold!</h1>
    </ion-content>
    <ion-footer-bar align-title="left" class="bar-assertive">
      <h1 class="title">footer</h1>
    </ion-footer-bar>
  </body>
</html>


  • 整体是 SPA(Single Page Application)
  • 除过index.html外的所有页面(放入templates文件夹下)通过Ajax加载
  • 基于Angular UI做页面路由
  • Controller中做事件绑定和数据绑定
  • View复杂的处理使用Directive・Filter
  • Model中的共通处理委托给Service、Factory

单纯使用CSS(ionic很多功能是通过JS实现的所以只使用单纯CSS意义不大):
<!DOCTYPE html>
<html>
  <head>
    <meta charset="utf-8">
    <meta name="viewport" content="initial-scale=1, maximum-scale=1, user-scalable=no, width=device-width">
    <link href="lib/ionic/css/ionic.css" rel="stylesheet">
  </head>
  <body>
    <div class="bar bar-header bar-positive">
      <h1 class="title">header</h1>
    </div>
    <div class="scroll-content has-header has-footer">
      <div class="card">
        <div class="item item-divider">
          I'm a Header in a Card!
        </div>
        <div class="item item-text-wrap">
          This is a basic Card with some text.
        </div>
        <div class="item item-divider">
          I'm a Footer in a Card!
        </div>
      </div>
      <div class="card">
        <div class="item item-divider">
          I'm a Header in a Card!
        </div>
        <div class="item item-text-wrap">
          This is a basic Card with some text.
        </div>
        <div class="item item-divider">
          I'm a Footer in a Card!
        </div>
      </div>
    </div>
    <div class="bar bar-footer bar-positive">
      <h1 class="title">footer</h1>
    </div>
  </body>
</html>


几个完整的Project模板ionFullApp、ionWordpress。
http://codecanyon.net/collections/4884964-ionic-apps

AngularJS Chrome调试插件Batarang
Building Beautiful Mobile Apps In Visualforce Using AngularJS And Ionic Part 1Part 2Part 3
http://www.zhouwenbin.com/tag/ionic/
http://julienrenaux.fr/2014/05/09/ionic-framework-features-you-may-have-missed/
  • 大小: 26.7 KB
  • 大小: 36.1 KB
分享到:
评论

相关推荐

    Cordova 3.x入门

    在本书中,作者rensanning将带领读者入门Cordova 3.x,涵盖了基础知识点、实用插件、源码分析和实例开发等方面的内容。 首先,作者介绍了如何在Windows和Android环境下搭建Cordova开发环境,这是开发移动应用的第一...

    generatorm-chkbox:AngularJS、Ionic、generator-m 和复选框

    发电机-M v1.1.0为什么需要它使用您喜欢的工具快速构建移动 Cordova/PhoneGap 应用...ui/ui-router 离子- http://ionicframework.com/ ngCordova - http://ngcordova.com/ 科尔多瓦- http://cordova.apache.org/ 许多

    ionic-framework-master.zip

    "ionic-framework-master.zip" 文件很可能包含了Ionic Framework的源代码仓库,通常用于开发和学习。 在解压"ionic-framework-master"后,我们可以期待找到以下关键组成部分: 1. **项目结构**:在根目录下,通常...

    Ionic Framework by Example

    - **Ionic Framework**:Ionic是一款开源的移动应用开发框架,主要基于HTML5、CSS3和JavaScript等Web技术构建,支持通过Apache Cordova或Capacitor等插件将Web应用打包成原生应用。它旨在帮助开发者使用现代Web技术...

    前端项目-ionic-framework.zip

    《深入理解Ionic Framework:构建高性能前端移动应用》 Ionic Framework是一款基于Angular的开源HTML5移动应用框架,旨在帮助开发者利用Web技术(如HTML、CSS和JavaScript)构建原生感观的移动应用程序。它以其强大...

    Mobile App Development with Ionic 2

    Learn how to build app store-ready hybrid apps with the Ionic 2, the framework built on top of Apache Cordova (formerly PhoneGap) and Angular. This practical guide shows you how to use Ionic’s tools ...

    ionic初学者填坑.docx

    Ionic是一个开源的UI框架,主要用于构建高质量的跨平台移动应用。它基于HTML、CSS和JavaScript等Web技术,结合了AngularJS和Cordova(或PhoneGap)来实现原生功能调用。 #### 二、准备工作与环境搭建 **1. Node.js ...

    ionic-thing-app:物联网应用

    Generator-M v1.2.2 为什么需要它 使用您喜欢的工具快速构建移动Cordova / PhoneGap应用程序:Yeoman,Gulp,... 离子-http : //ionicframework.com/ ngCordova - http: //ngcordova.com/ 科尔多瓦-http : //cordov

    thing-app:一个用于测试oauth之类的Ionic应用

    Generator-M v1.2.2为什么需要它使用您喜欢的工具快速构建移动Cordova / PhoneGap应用程序:Yeoman,...ui/ui-router 离子-http : //ionicframework.com/ ngCordova - http: //ngcordova.com/ 科尔多瓦-http : //cordov

    ionicframework官方例子

    1. **离子组件(Ionic Components)**:Ionic 提供了一系列的UI组件,如侧滑菜单、下拉刷新、选项卡、模态框、弹出提示、浮动按钮等,这些都是构建移动应用界面的基础。 2. **AngularJS集成**:Ionic 使用AngularJS...

    Ionic3-D3-Chart:Ionic3 D3.js

    【标题】"Ionic3-D3-Chart:使用D3.js在Ionic3框架中的图表应用" 【描述】"这个项目展示了如何在Ionic3框架内集成D3.js库来创建动态、交互式的图表。它是一个Android APK应用程序,允许用户在移动设备上体验基于D3...

    ionic-audio:适用于Ionic 3和Angular 4的音频播放器。可使用Cordova Media插件处理HTML 5音频或本机音频

    1. **跨平台支持**:由于基于Ionic框架,`ionic-audio`能够轻松构建可在Android、iOS等不同平台上运行的混合移动应用。 2. **Cordova Media插件**:通过集成Cordova Media,`ionic-audio`可以访问设备的音频硬件,...

    ionicPaper:开始学习离子

    Generator-M v1.1.0 为什么需要它 使用您喜欢的工具快速构建移动Cordova / PhoneGap应用程序:Yeoman,Gulp,... 离子-http : //ionicframework.com/ ngCordova - http: //ngcordova.com/ 科尔多瓦-http : //cordov

    ionic手机APP开发从入门到精通,环境搭建到创建自己的APP

    - 更多关于模板的详细信息,请参考[Ionic官方文档](https://ionicframework.com/docs/cli/commands/start)。 #### 五、框架目录结构 - 创建的新项目通常会有一个标准的目录结构,包括但不限于: - `src`:存放所有...

    Ionic : Hybrid Mobile App Development

    Develop engaging mobile experiences with a native-looking UI in Ionic and AngularJS. Use out-of-the-box Ionic functionalities, customize existing components, and add new components with this ...

    前端项目-quasar-framework.zip

    1. **Quasar Framework**:Quasar是一个开源的Web UI框架,基于Vue.js,用于快速开发响应式和高性能的Web应用、PWA(渐进式Web应用)、Electron应用、Cordova或Capacitor应用。它提供了丰富的组件库和工具链,简化了...

    基于IONIC framework的HTML5双平台APP.zip

    IONIC Framework是一款开源的前端框架,基于AngularJS和Apache Cordova,专为构建原生感观的混合移动应用而设计。它提供了一套丰富的UI组件和工具,帮助开发者使用Web技术(如HTML、CSS和JavaScript)创建功能完备、...

    IONIC 功能全演示

    Ionic本身是致力于建立统一的移动混合app构建平台,核心基础是Angular+Cordova。 - 通过Angular指令封装,以及预定义的CSS,提供了开箱即用的HTML5 Mobile组件。 - 构建与开发支持,能够直接运行www目录下的index....

    ionic框架参考手册中文

    1. **离子(Ion)组件**:Ionic的核心在于其丰富的UI组件库,包括导航栏(Navbar)、侧滑菜单(Sidebar)、抽屉(Drawer)、卡片(Card)、按钮(Button)、表单元素(Forms)、列表(List)、网格(Grid)等。这些组件设计精美,...

Global site tag (gtag.js) - Google Analytics