Cordova历史发展
- ・2009年 通过iPhoneDevCamp之后,加拿大Nitobi开发了PhoneGap
- ・2011年 7月28日PhoneGap 1.0.0发布
- ・2011年 10月Adobe收购了Nitobi,并把PhoneGap的核心代码codebase捐给了Apache基金会,但保留了PhoneGap的商标所有权
- ・2011年 Apache最开始孵化这项目时用的名是Apache Callback(PhoneGap 1.1.0)
- ・2012年 PhoneGap更新到1.4版本后,用Nitobi旧址的街道名Cordova重新命名了这个项目,更广的用户和贡献者、管理透明、更好的文档;但是也产生了品牌歧义(Phonegap、Cordova)
http://en.wikipedia.org/wiki/PhoneGap
所以,可以把PhoneGap理解为Cordova的一个distribution,但它或多或少的和Cordova有所不同,当然很多不同也是因为要支持PhoneGap Build的。PhoneGap和Cordova的关系就如同Safari和WebKit的关系。
PhoneGap is a distribution of Apache Cordova.
前提版本:
引用
#cordova -v
3.4.1-0.1.0
#phonegap -v
3.4.0-0.19.21
(1)CLI
从以下的依赖关系可以看出PhoneGap实际上内部就是使用了Cordova。
引用
phonegap@4.2.0-0.24.2
├── pluralize@0.0.4
├── colors@0.6.0-1
├── semver@1.1.0
├── minimist@0.1.0
├── qrcode-terminal@0.9.4
├── shelljs@0.1.4
├── prompt@0.2.11 (revalidator@0.1.8, pkginfo@0.3.0, read@1.0.5, winston@0.6.
2, utile@0.2.1)
├── phonegap-build@0.9.1 (qrcode-terminal@0.8.0, optimist@0.3.7, shelljs@0.0.
9, phonegap-build-api@0.3.3)
├── connect-phonegap@0.14.8 (home-dir@0.1.2, connect-inject@0.3.2, ip@0.3.1,
ncp@0.6.0, findit@2.0.0, shelljs@0.2.6, request-progress@0.3.1, http-proxy@1.8.1
, useragent@2.0.8, gaze@0.4.3, tar@0.1.19, node-static@0.7.0, request@2.33.0, ar
chiver@0.10.1, localtunnel@1.3.0, connect@2.12.0, socket.io@1.0.4)
└── cordova@4.2.0 (underscore@1.7.0, q@1.0.1, nopt@3.0.1, cordova-lib@4.2.0)
查看命令的说明:
引用
#phonegap help
#cordova help
官方说明:
https://github.com/apache/cordova-cli
https://github.com/phonegap/phonegap-cli
最常用的命令都是相似的,Adobe给PhoneGap添加了一些Cordova没有的特性,比如remote build。
1)create命令
引用
E:\projects>cordova create c1
Creating a new cordova project with name "HelloCordova" and id "io.cordova.hellocordova" at location "E:\projects\c1"
引用
E:\projects>phonegap create p1
[phonegap] the options E:\projects\p1 com.phonegap.helloworld HelloWorld
[phonegap] created project at E:\projects\p1
phonegap cli命令中不能指定name和id,需要手动修改config.xml
参考:
https://github.com/phonegap/phonegap-cli/issues/263
2)build命令
phonegap build 统一了Cordova的以下命令:
- cordova platform add
- cordova prepare
- cordova compile
3)serve命令
- phonegap serve不需要添加平台直接使用,默认端口3000
- cordova serve需要添加平台后使用,默认端口8000
4)local/remote命令
“phonegap local *”
- build <platform> build a specific platform
- install <platform> install a specific platform
- run <platform> build and install a specific platform
- plugin <command> add, remove, and list plugins
“phonegap remote *”
- login login to PhoneGap/Build
- logout logout of PhoneGap/Build
- build <platform> build a specific platform
- install <platform> install a specific platform
- run <platform> build and install a specific platform
cordova emulate 等价于 phonegap local run。
cordova cli更像是Phonegap的local build。
https://github.com/phonegap/phonegap-cli/blob/master/lib/phonegap/util/platform.js
'local' => cordova-cli
'remote' => PhoneGap/Build
phonegap的project命令都会判断是否该工程下有.cordova文件夹。
Cordova判断的是www platforms config.xml
(2)Project
1)www/spec
jasmine的测试代码
2)www/res
phonegap build支持icon和splash
3)config.xml
文件位置
phonegap: /www/config.xml
cordova: /config.xml
***cordova也支持读取www下的config.xml
文件内容:
<icon src="" />
<gap:splash src="" />
<gap:plugin name="org.apache.cordova.camera" />
4)index.html
<script type="text/javascript" src="cordova.js"></script>
<script type="text/javascript" src="phonegap.js"></script>
cordova.js 和 phonegap.js的内容完全是一样的,而且phonegap的native工程里也有cordova.js。
(3)Plugin
phonegap plugin add 是用于phonegap local build的,phonegap remote build的plugin需要在config.xml中添加,互不相干。
(4)其他
- Phonegap独有功能:Phonegap Build、Phonegap Enterprise、Phonegap Developer App等。
- Phonegap使用Cordova,但是各自管理版本,一般Cordova先发布,Phonegap会随后才支持新版。
- Phonegap Build里只能使用Phonegap的插件,而Cordova可以导入任意插件。
参考:
http://blog.tiger-workshop.com/difference-between-phonegap-and-cordova/
分享到:
相关推荐
win7(32位)环境下phonegap(cordova)环境的搭建过程,花了2天时间整理的,对初学者应该有所帮助。
百度移动广告联盟phonegap/cordova插件,百度ssp广告phonegap插件,支持cordova和phonegap打包的ios和android应用,简单好用,只需要几行js就能在phonegap和cordova应用里面接入百度广告
PhoneGap/Cordova的支付宝Android插件
phonegap/Cordova和android自定义插件模块,cordova build后插件不会消失
基于undroid的phoneGap(cordova)开发步骤代码
移动开发框架
phonegap cordova 最简单的android应用例子,直接执行cordova run android 进行编译后可以在手机上浏览效果
InstagramPlugin, 用于 phonegap/cordova的Instagram 插件 Cordova Instagram 插件由 。使用dataUrl和Android的Instagram 应用程序添加用于共享画布元素或者编码图像的内容的能力。 将插件安装到你的项目中如果使用...
基于cordova1.7版本,将api中实例汇总在一起并在iphone4s机器上调试通过
已经装eclipse,android sdk及adt的安装和配置。 1.进入eclipse界面,新建android工程 new > android project 2.该工程目录下建立两个文档 /libs 和 /assets/www 3.把phonegap中android目录下的cordova-1.7.0.js...
使用phonegap(Cordova)快速集成H5界面,速成app。适用性强,一套H5界面,多个平台使用。
看完还是不会,建议你就不要再学移动开发了
鉴于目前网上流行的资料关于PhoneGap Cordova 的配置教程几乎都是1 3版本 另外又由于官网的文档漏洞百出 一直报:java lang RuntimeException:Unable to start activity ComponeInfo{...然后本人摸索了好久 终于找到了...
使用说明: 1、百度云推送 打开AndroidManifest.xml,将百度开发者中心api_key复制value后的引号中。 <meta-data android:name="api_key" android:value="" /> ...fastgoPushNotification.init("apk_key");...
一些简单的入门级的例子,适合初级者,希望对大家有所帮助
pouchdb-phonegap-cordova PouchDB 在 PhoneGap 和 Cordova 上运行良好。 以下是如何开始。示例应用程序安装只需下载并将其包含在您的index.html : < script src =" ./path/to/pouchdb.js " > </ script ...
cordova platform add android cordova build 上图展示的就是移动接口能力 APP的开发的中:一般不会采用嵌入网页这样的低端模式。 网页还有,但这时的网页,就是一个骨架而已。 高级饭店里的萝卜不是用来吃的...
phonegap cordova简明环境配置入门文档 phonegap cordova 简明 环境配置 入门 连接真实机器调试,目录结构介绍, eclipse html插件的下载和安装
该项目文件集成了Cordova自带的通讯录插件,以及自己封装好的Cordova插件,可添加打开通讯录
phoneGap cordova 学习示例,直接导入eclipseADT即可.