第一次接触cordova,从环境搭建到打包第一个apk踩了蛮多坑的,写篇教程给大家参考一下
最后成果
安装前环境:
1、win10系统
2、java jdk 版本是 v1.8.0(java jdk是很早之前就安装了的,关于java jdk的配置教程满多的,这里就不絮叨这个了)
3、我是前端,node.js是我必备软件之一,我目前的版本是v8.11.1
安装node
这是node下载链接
推荐点击这个node安装蛮简单的,一路next就好
安装完成后可以用 node -v查看版本
Android SDK 环境变量配置
下载地址 http://www.androiddevtools.cn/,这个地方我只需要sdk不需要他的编辑器所以这个地方我们就只下载sdk
1、下载解压至D:\Program Files\androidSDK
,出现下图
3、原有不用取消继续勾选
勾选最后一个--最后install
5、如果出现了这个
那么你很幸运去第7步配置环境变量吧
如果你出现了一个Warning!的警告框提示你有程序占用了这个文件夹,那么你跟我一样很倒霉,看第六步
6、删掉之前那个文件夹,重新解压安装包到一个空文件夹,复制tools,命名为tools-copy
在tools-copy目录运行 android.bat ,这样就可以正常安装完了
7、新建系统变量
名:ANDROID_HOME
值:c:\tools_r25.2.3-windows”
编辑环境变量Path,在弹框里点击新建,你可以向我一样输入3条,也可以这样
值:
;%ANDROID_HOME%\build-tools\27.0.3;%ANDROID_HOME%\platform-tools;%ANDROID_HOME%\tools;
需要注意的是27.0.3是build-tools文件夹中的一个文件夹的名字
8、终端中输入adb,出现下图表示成功
安装ant
下载链接:https://ant.apache.org/bindownload.cgi
1、下载第一个就好
2、下载完成之后解压到你想安装的目录,比如我是D:\Program Files\ant
3、右击我的电脑--属性--高级系统设置--环境变量--点击新建用户变量
名:ANT_HOME
值:D:\Program Files\ant
4、终端输入ant -v出现以下画面表示安装成功
安装gradle
下载链接http://services.gradle.org/distributions/
1、下载解压至D:\Program Files\gradle-4.7
2、右击我的电脑--属性--高级系统设置--环境变量--在系统变量里找到Path点击编辑
在编辑环境变量的弹框内点击新建
输入D:\Program Files\gradle-4.7\bin 点击确定
3、终端输入 gradle -v出现下图安装成功
安装cordova
不容易,终于来到这一步了
1、全局安装
npm install -g cordova
2、cd到你想要创建项目的文件夹,cordova create是创建项目的命令,hello为本地文件夹名称,com.example.hello为项目id,HelloWorld为最后app的名称
$ cordova create hello com.example.hello HelloWorld
执行成功后,项目目录变成了这样
<u>目录结构说明</u>
hooks:存放自定义cordova命令的脚本文件。
config.xml :cordova的配置文件
www:工作目录,所有的html,js之类的文件默认加载到index.html,在cordova prepare时被copy到各个平台的assert的www目录中
plugins:已安装的插件
platforms:各平台的工程目录,cordova编译工程时会将其覆盖
3、给你的App添加目标平台,现在我们添加android'平台,并确保他们保存在了config.xml中
$ cordova platform add android --save
出现这个表示你安装添加成功
检查你当前平台设置状况
cordova platform ls
如果你顺利添加成功没有报任何error,运行这个命令会是这样的
如果报了error那就肯定没有成功installed platforms是空的
我一向很倒霉,如果你跟我一样倒霉,那么就看下我试过的各种方法Cordova add android 报错4种解决方法
5、运行cordova build android进行打包,时间会有点长,
打包完成后可以在项目文件夹platforms\android\app\build\outputs\apk\debug内找到打包好的apk文件
欢迎留言交流 (´▽`ʃ♡ƪ)**