翻译自cordova官方文档(如果需要链接,请自行对照原文链接进行查看):
https://cordova.apache.org/docs/en/6.x/guide/cli/index.html
本章主要介绍如何使用Cordova的命令行工具(Command-Line-Interface)
首先在运行任何命令之前,需要安装对应平台的SDK,目前Cordova支持的开发平台主要有以下几个平台:
iOS (Mac)
Amazon Fire OS (Mac, Linux, Windows)
Android (Mac, Linux, Windows)
BlackBerry 10 (Mac, Linux, Windows)
Windows Phone 8 (Windows)
Windows (Windows)
Firefox OS (Mac, Linux, Windows)
首先需要安装Nodejs环境,然后安装npm,然后使用命令:
$ sudo npm install -g cordova
C:\>npm install -g cordova
/******************************************************************
*npm是你要执行的命令
*install 是表示安装
*cordova是你要安装的软件
*-g是全局安装,这样你就可以在你的命令行任意目录下执行cordova命令了.
*如果是Windows你需要在Path中设置npm的安装路径以达到在任何目录下都能使用该命令的目的.
*****************************************************************/
安装成功以后输入如下指令可以得到版本信息表示安装成功
$ cordova -v # 6.0.0
命令语法:$ cordova create project_path com.project.appname appname
$ cordova create CordovaCn com.cordovacn CordovaCnApp
/******************************************************************
*cordova 执行的命令
*create 命令cordova创建工程
*project_path 创建程序根目录的名称
*com.project.appname 创建程序标识符,也就是identifier,以后可以在程序里修改,不过改的地方很多
*appname 程序名称,默认值是HelloCordova
******************************************************************/
添加平台首先要进入到你创建的Cordova工程根目录,比如:
$ cd CordovaCn
此后,可以通过下面的命令添加对应的app需要支持的移动平台
$ cordova platformadd ios
$ cordova platformadd amazon-fireos
$ cordova platformadd android
$ cordova platformadd blackberry10
$ cordova platformadd firefoxos
/****************************************************************
*提示:在添加平台以前,最好先设置好splashscreen插件以后在进行平台的添加这样可以避免很多麻烦
*很多人经常反应说配置了splashscreen插件,但是icon和splash却还是默认图片。
*这里主要原因是很多Cordova开发者对原生开发并不熟悉,因此不会针对原生工程进行icon和splashscreen的设置
*但是如果在platform add命令以前进行设置,然后添加对应移动平台的时候,Cordova会帮你解决一切问题
***************************************************************/
通过以下命令来罗列出目前Cordova支持哪些平台以及当前工程添加了哪些平台
$ cordova platforms ls
/*****************************************************************
*运行结果如下,当前是没有添加任何支持平台,所以第一行为空
*Installed platforms:
*Available platforms: amazon-fireos, android, blackberry10, browser, firefoxos, ios, osx, webos
****************************************************************/
myapp/|--config.xml#cordova的核心配置文件,在下一章节进行详细说明<br>
|--hooks/#该目录主要是针对Cordova做一些动作的监听,我暂时也没有详细研究,稍后补充<br>
|--www/#在对html,JavaScript,CSS文件进行编辑的时候主要是在该目录进行,而后通过prepare命令同步到各个平台目录<br>
|--platforms/#生成的针对各个平台的平台工程目录,不要编辑此目录下任何文件,除非你只发布指定平台的app<br>
||--android/||--ios/--plugins/#安装插件的时候,会将插件的原始代码存放到此文件夹。大家在使用插件遇到问题的时候,请到这个目录查找readme文件<br>
$ cordova platformremove blackberry10
$ cordova platform rm amazon-fireos
$ cordova platform rm android
$ cordova platform check
#Creating Cordova project for the Android platform:# Path: ../../../../var/folders/57/37gyvl514rj0js8485bfkqdc0000gn/T/cordova-platform-check-1457411506890/platforms/android# Package: io.cordova.hellocordova# Name: HelloCordova# Activity: MainActivity# Android target: android-22#Copying template files...#Android project created with cordova-android@4.1.1 #当前生成的android工程镜像是使用的4.1.1,可以被更新。
$ cordova platform update android
$ cordova platform update ios
...etc.
可以通过以下的命令进行对工程的构建操作
$ cordova build
$ cordova build ios // 只build ios平台
其实cordova build命令就是以下一组命令的快捷方式
$ cordova prepare ios
$ cordova compile ios
在一般情况下,如果开发者对各个移动平台的开发工具使用很熟悉的情况下。我的建议是直接使用cordova prepare来进行代码同步。同步config.xml文件的信息到指定平台的配置文件,并拷贝icons&splashscreen,拷贝plugin文件到指定平台。然后通过对应平台的开发工具来进行编译调试等工作。
$ cordova prepare ios
$ cordova emulate android
从我个人建议,我是并不建议通过Cordova的指令来对app进行调试和运行的。我还是建议使用特定平台的开发工具来进行此类操作比如Android studio,XCode,Eclipse等。
$ cordova run android
清理工程,主要用于清理工程跟其他编译工具的clean功能是一样的。当项目代码出现莫名其妙问题的时候,同步的文件没有及时反应到开发环境的时候,可以尝试此操作。
$ cordova clean android
emulate,build和run命令需要一些环境配置,所以对于很多人来说经常会遇到很多麻烦。这里我还是建议大家尽可能使用Android或者ios等特定平台的指定开发工具进行调试和运行。比如Android Studio或者XCode
Cordova的插件(plugin)是Cordova为web提供的与移动平台原生api交互的桥梁,而在Cordova官方已经为大家提供了非常丰富的plugin来使用,一般情况下是不需要自己单独开发的。
当你需要一个功能插件的时候,但是又不知道叫什么名字,可以通过如下命令来查找你需要的插件:
$ cordova plugin search bar code
// com.phonegap.plugins.barcodescanner - Scans Barcodes
// cordova-plugin-statusbar - Cordova StatusBar Plugin
通过cordova plugin add我们可以到指定的库或者目录去安装指定的插件,下面是apache已经提供的一些基本的功能插件
//基本设备信息
$ cordova plugin add cordova-plugin-device//网络相关
$ cordova plugin add cordova-plugin-network-information//电池相关
$ cordova plugin add cordova-plugin-battery-status//速度传感器
$ cordova plugin add cordova-plugin-device-motion//指南针
$ cordova plugin add cordova-plugin-device-orientation//地理位置
$ cordova plugin add cordova-plugin-geolocation//相机相关
$ cordova plugin add cordova-plugin-camera//媒体相关
$ cordova plugin add cordova-plugin-media-capture
$ cordova plugin add cordova-plugin-media//访问设备和网络上的文件
$ cordova plugin add cordova-plugin-file
$ cordova plugin add cordova-plugin-file-transfer//对话框和手机振动
$ cordova plugin add cordova-plugin-dialogs
$ cordova plugin add cordova-plugin-vibration//联系人
$ cordova plugin add cordova-plugin-contacts//全球化
$ cordova plugin add cordova-plugin-globalization//启动画面,又叫闪屏
$ cordova plugin add cordova-plugin-splashscreen//打开新浏览器
$ cordova plugin add cordova-plugin-inappbrowser//调试控制台
$ cordova plugin add cordova-plugin-console
$ cordova plugin ls # or 'plugin list'
$ cordova plugin rm cordova-plugin-console
$ cordova plugin remove cordova-plugin-console
$ cordova plugin add cordova-plugin-console@latest$ cordova plugin add cordova-plugin-console@0.2.1
$ cordova plugin add https://github.com/apache/cordova-plugin-console.git
$ cordova plugin add https://github.com/apache/cordova-plugin-console.git#r0.2.0
$ cordova plugin add https://github.com/apache/cordova-plugin-console.git#CB-8438cordova-plugin-console
$ cordova plugin add https://github.com/apache/cordova-plugin-console.git#f055daec45575bf08538f885e09c85a0eba363ff
$ cordova plugin add https://github.com/someone/aplugin.git#:/my/sub/dir
$ cordova plugin add https://github.com/someone/aplugin.git#r0.0.1:/my/sub/dir
$ cordova plugin add ../my_plugin_dir
在工程根目录下创建merges目录结构如下:
merges
--android
--ios
里面存放的文件,当rebuild的时候不会被根目录www目录下的文件所覆盖,这样就可以保留针对特定平台而使用的css,js,html而不用每次build后回滚代码了。
$ cordova help
$ cordova # same$ cordova run --help # 查看run命令的详细帮助$ cordova info # 查看cordova命令的详细
$ sudo npm update -g cordova
$ sudo npm install -g cordova@3.1.0-0.2.0# 升级到指定版本