Cordova之入门

什么是Cordova

  Cordova前身是PhoneGap,而PhoneGap是Nitobi软件公司2008年推出的一个框架,旨在弥补web和iOS之间的不足,使得webiPhone SDK之间的交互更容易,后来又陆续加入了更多的平台。

  • Cordova提供了一组设备相关的API,通过这组API,移动应用能够以JavaScript访问原生的设备功能,如摄像头、麦克风等。
  • Cordova还提供了一组统一的JavaScript类库,以及为这些类库所用的设备相关的原生后台代码。
  • Cordova支持如下移动操作系统:iOS, Android,ubuntu phone os, Blackberry, Windows Phone, Palm WebOS, Bada 和 Symbian。

安装Cordova

  1. 下载和安装Node.js,安装成功后在命令行使用
$ node -v  
$ npm -v   
  1. 查看是否安装成功,npmnode.js的包管理器(Package manager)。
  2. 下载和安装Git,安装成功后,你可以在命令行使用git,在自定义导入插件时使用。
  3. 安装cordova使用node.jsnpm工具。cordova模板会被自动下载
  • 在Mac或Linux中,使用终端,安装cordova
$ sudo npm install -g cordova
  • 在Windows中,使用cmd命令行全局安装cordova
 C:\>npm install -g cordova

创建App

  打开命令或终端

$ cordova create hello com.hello.demo HelloWorld

  这将会为你的cordova应用创造必须的目录。默认情况下,cordova create命令生成基于web的应用程序的骨骼,项目的主页是 www/index.html文件。

项目结构介绍
hello/
| -- hooks/
| -- node_modules/
| -- platforms/
|  |  | -- android/
|  |  | -- ios/
| -- plugins
| -- res
| -- www
| -- config.xml
| -- package.json
  • hooks 包含自定CLI命令的脚本,用于集成自己的版本控制系统或构建系统。
  • node_modules 文件夹是项目npm中所依赖的文件
  • platforms 添加平台后的目录文件
  • plugins 项目包含插件目录
  • res 资源文件目录
  • www 存放web项目的目录
  • config.xml 项目配置文件
  • package.json npm依赖项目配置

注意:
www目录下内容,在项目编译时,将把此文件下文件复制至/platforms/android/app/src/main/assets/
node_moduses文件出错,可删除文件夹,检查package.json,使用命令$ npm install重新添加

添加平台

所有后续命令都需要在项目或项目目录中进行

$ cd hello 

进入hello目录,根据需要添加iosandroid平台,并确保他们保存在config.xml中。

$ cordova platform add android --save
$ cordova platform add ios --svae

删除已添加平台

$ cordova platform remove android 

检查当前平台设置状态

$ cordova platform ls

运行addremove平台的命令将会影响项目platform的内容,在这个平台中,每个平台都有一个子目录。

注意:在使用CLI创建应用的时候,不要修改 /platform/目录中的任何文件,当准备构建应用和安装插件时这个目录会被重写。

编译安装

要构建和运行App,需要安装每个你所需要的平台。

检查是否满足构建标准

$ cordova requirements
Requirements check results for android:
Java JDK: installed .
Android SDK: installed
Android target: installed android-19,android-21,android-22,android-23,Google Inc.:Google APIs:19,Google Inc.:Google APIs (x86 System Image):19,Google Inc.:Google APIs:23
Gradle: installed

Requirements check results for ios:
Apple OS X: not installed
Cordova tooling for iOS requires Apple OS X
Error: Some of requirements check failed

系楼主android开发,所以只配置了 JDK SDK Gradle环境变量,具体配置及安装百度。

构建App

默认情况下,cordova create 创建基于web应用程序的结构,项目开始界面位于www/index.html文件。任何初始化任务应该放在www/js/index.js文件的deviceready事件的处理函数中。

运行以下命令为所有添加的平台构建

$ cordova build

如果需要单独为某个平台构建

$ cordova build android
$ cordova build ios
测试App

以下命令使用SDK默认模拟器打开

$ cordova emulate android

或者,插入你的android手机,在手机上直接测试App

$ cordova run android

注意,在运行App时,可能会出现长时间编译不动,或者构建出错,是因为gradle被墙,项目依赖等文件无法下载导致的问题,可使用国内阿里云镜像

具体使用过程,打开目录的/platforms/android/build.gradle文件 和 /platforms/android/app/build.gradle文件中添加。

    repositories {
        maven { url 'http://maven.aliyun.com/nexus/content/groups/public/' }
        jcenter()
        mavenCentral()
    }

添加插件

如果App要接触设备级别的特性,就需要添加插件了,你可以在插件搜索页去查找自己所需的插件。

  • 例:添加相机插件
cordova plugin add cordova-plugin-camera

插件也可以通过目录git地址去添加

通过plugin ls 或者 plugin list 可查看项目所有已添加的插件

$ cordova plugin ls
cordova-plugin-camera 4.0.3 "Camera"
cordova-plugin-whitelist 1.3.3 "Whitelist"

更新Cordova和项目

在安装cordova工具之后,可运行一下命令更新到最新版本

$ sudo npm update -g cordova

用下面语法安装指定版本:

$ sudo npm install -g cordova@3.1.0-0.2.0

运行cordova -v查看当前版本。要查找最新的cordova版本,可以运行:

$ npm info cordova version

更新完cordova后,更新目标项目的平台:

$ cordova platform update android --save
$ cordova platform update ios --save
...etc.
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 202,980评论 5 476
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 85,178评论 2 380
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 149,868评论 0 336
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,498评论 1 273
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,492评论 5 364
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,521评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,910评论 3 395
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,569评论 0 256
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,793评论 1 296
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,559评论 2 319
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,639评论 1 329
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,342评论 4 318
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,931评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,904评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,144评论 1 259
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 42,833评论 2 349
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,350评论 2 342