H5开发HybridApp

1 H5开发

开发HybridApp一般都是先完成H5部分,所谓的H5就是Html5页面,开发的时候我们在PC机上的浏览器调试即可,这里推荐Chrome F12模式。

clip_image002

在调试服务器请求数据部分要给chrome设置跨域模式,如下:

clip_image004

然后以管理员的身份启动chrome:

clip_image006

开发H5,建议使用HBuilder,开发速度很快

clip_image008

接下来安装cordova,本地需要已安装nodejs,确保可以正常使用npm命令。因为npm默认链接的是国外的源,所以如果网络不给力的话要切换成国内的源,比如淘宝的npm,具体如何切换,请百度。

2 安装cordova

clip_image010

Cordova创建项目官方文档

http://cordova.apache.org/docs/en/latest/guide/cli/index.html

3 创建项目

clip_image012

进入项目

clip_image014

添加平台

clip_image016

clip_image018

查看已添加的平台

clip_image020

4 添加插件

http://cordova.apache.org/docs/en/latest/guide/cli/index.html#link-add-plugin-features

设备基本信息插件

clip_image022

网络模块

clip_image024

电池状态

clip_image026

加速度计模块

clip_image028

罗盘模块

clip_image030

定位模块

clip_image032

相机模块

clip_image034

文件管理模块

clip_image036

弹出框

clip_image038

重力感应

clip_image040

通讯录接口

clip_image042

国际化

clip_image044

启动页

clip_image046

内置浏览器

clip_image048

日志模块

clip_image050

查看已安装插件

clip_image052

如果要移除插件

cordova plugin rm XXX

5 插件调用

http://cordova.apache.org/docs/en/latest/cordova/plugins/pluginapis.html

6 项目导入

以Android为例,IOS更简单,直接双击.xcodeproj即可在xcode里面打开项目

Eclipse > Import> Existing Android Code Into Workspace >

clip_image054

项目导入之后如下:

clip_image056

7 H5集成

接下来我们把上面开发好的H5导入到工程里面来,导入H5部分需要注意,有两种方式,第一种也是官方文档使用的方式,即直接把H5内容复制到platform_www下面,然后通过cordova update 命令来同时更新到多个平台。

clip_image058

但是cordova update这种方式有个缺点就是通过这种全面覆盖的方式就无法保留不同平台之间H5代码的差异性,所以尤其是项目后期,不建议采用这种方式来操作。

另外一种方式是直接复制H5代码到不同平台下,分别调试:

clip_image060

设置首页

打开MainActivity.java

clip_image062

IOS是直接在config.xml里面配置即可。

引入cordova.js

H5页面引入cordova.js

clip_image064

APP图标和启动页

clip_image066

8 APP打包

接下来就可以直接Run As 运行打包了,如果有连着android手机,可以直接在手机上查看效果。

clip_image068

如果无法连接真机调试,可以打包成apk后另行安装:

右键项目>Android Tools>Export Signed Application package… 或者 Export UnSigned Application package… ,如果有签名文件就选Signed,反之UnSigned。

9 自定义插件

开头部分已经提到插件这个词,插件就是cordova封装了一套通过js来访问硬件设备的接口,那如果我们要自己实现一个插件该怎么做,可以查看官方文档,按照cordova的规范来编写:

http://cordova.apache.org/docs/en/latest/guide/hybrid/plugins/index.html

这里举个简单的例子,比如我们要开发个Toast,众所周知Toast这种效果一般要通过android的Toast.makeText()方法来实现,那我们怎么通过js来调用这个原生的方法呢,步骤如下:

1) 创建原生实现类ToastPlugin.java

实现如下:

clip_image070

2) 创建js实现类ToastPlugin.js

实现如下:

clip_image072

3) 配置路由res/xml/config.xml

clip_image074

4) 调用

接下来就可以在html页面通过toast(“XXX”);这种方式来调用了。

Ios插件的实现步骤跟android大概一致,只是ToastPlugin.java ios对应的要用原生Object-c去实现。

完。

posted @ 2016-02-05 16:57  Jager  阅读(2211)  评论(0编辑  收藏  举报