`
rensanning
  • 浏览: 3558104 次
  • 性别: Icon_minigender_1
  • 来自: 大连
博客专栏
Efef1dba-f7dd-3931-8a61-8e1c76c3e39f
使用Titanium Mo...
浏览量:38318
Bbab2146-6e1d-3c50-acd6-c8bae29e307d
Cordova 3.x入门...
浏览量:608074
C08766e7-8a33-3f9b-9155-654af05c3484
常用Java开源Libra...
浏览量:683279
77063fb3-0ee7-3bfa-9c72-2a0234ebf83e
搭建 CentOS 6 服...
浏览量:89886
E40e5e76-1f3b-398e-b6a6-dc9cfbb38156
Spring Boot 入...
浏览量:402471
Abe39461-b089-344f-99fa-cdfbddea0e18
基于Spring Secu...
浏览量:69861
66a41a70-fdf0-3dc9-aa31-19b7e8b24672
MQTT入门
浏览量:92012
社区版块
存档分类
最新评论

Cordova 3.x 基础(11) -- JS是如何调用本地API的?

阅读更多
Cordova应用基于Webview,所以后台代码和js交互都是基于Webview(Webkit)的接口的。

Android:WebView(WebKit-based) WebView(4.4 Chromium-based)  Updatable-WebViews(5+)
@JavascriptInterface/WebView#addJavascriptInterface()
参考源码 ExposedJsApi.java

iOS:UIWebView(iOS 4+) WKWebView(iOS 8.1+)
UIWebViewDelegate/UIWebView#stringByEvaluatingJavaScriptFromString()
参考源码 CDVWebViewDelegate.m


以下以Android调用照相机为例,简单说明一下调用及回调过程。

(1)创建的过程

①添加插件
引用
cordova plugin add org.apache.cordova.camera

在plugins的目录下创建org.apache.cordova.camera文件夹,并将该Plugin的所有代码Copy进去,具体代码依赖关系都记录在plugin.xml里。

②创建Android工程
引用
cordova platform add android

从上边的Plugin文件夹中把Java文件和js文件Copy到Android工程的相应的文件夹下。
  • platforms\android\src\org\apache\cordova\camera\CameraLauncher.java等
  • platforms\android\assets\www\plugins\org.apache.cordova.camera\www\Camera.js等

其中CameraLauncher扩展自CordovaPlugin,而CordovaPlugin定义在platforms\android\CordovaLib中,它是Cordova的基础框架代码。

(2)调用的过程(JS->Native)

①HTML中引入cordova.js
引用
<script type="text/javascript" src="cordova.js"></script>

先做初始化处理,后根据cordova_plugins.js加载所有plugin的js文件。

②在deviceready事件中调用Camera
navigator.camera.getPicture(onSuccess, onFail,   
          { quality: 50,   
            allowEdit: true,   
            destinationType: destinationType.DATA_URL });
 

③调用Camera.js的getPicture方法
assets\www\plugins\org.apache.cordova.camera\www\Camera.js

getPicture()
->
exec(successCallback, errorCallback, "Camera", "takePicture", args)
->
function androidExec(success, fail, service, action, args) ***cordova.js
->
var messages = nativeApiProvider.get().exec(service, action, callbackId, argsJson);

④调入Java的exec()方法
在CordovaWebView初期化的时候会根据Android的版本,将ExposedJsApi对象添加到CordovaWebView中。
this.addJavascriptInterface(exposedJsApi, "_cordovaNative");
所以nativeApiProvider.get()的时候会根据 _cordovaNative 对象是否存在来判断是使用JavascriptInterface方式,还是使用prompt方式。

如果使用JavascriptInterface方式(Android 4.2以上版本),直接进入ExposedJsApi.java中定义了@JavascriptInterface标示的exec()方法 。

如果使用prompt方式,CordovaChromeClient.java中重写了onJsPrompt()方法,来调用exposedJsApi.exec()。
prompt(argsJson, 'gap:'+JSON.stringify([service, action, callbackId]));

总之入口都是exposedJsApi.exec().

@JavascriptInterface
public String exec(String service, String action, String callbackId, String arguments)
->
pluginManager.exec(service, action, callbackId, arguments);
PluginManager根据service调用获取到相应的CordovaPlugin
->
CameraLauncher.execute(String action, JSONArray args, CallbackContext callbackContext)
CameraLauncher根据action,这里是“takePicture”做本地API调用。
->
takePicture()
->
new Intent("android.media.action.IMAGE_CAPTURE");
cordova.startActivityForResult()
调用CordovaInterface(CordovaActivity->Activity)的startActivityForResult

(3)回调的过程(Native->JS)

①上述API调用成功后,在onActivityResult(CameraLauncher.java)设置结果
onActivityResult(int requestCode, int resultCode, Intent intent)

// Send Uri back to JavaScript for viewing image
this.callbackContext.success(uri.toString());

②退回到ExposedJsApi的exec()方法
jsMessageQueue.setPaused(false);
->
NativeToJsMessageQueue的onNativeToJsMessageAvailable()
->
sendMessageMethod = webViewCore.getClass().getDeclaredMethod("sendMessage", Message.class)
->
sendMessageMethod.invoke(webViewCore, execJsMessage)

③cordova.js中接收消息
androidExec.processMessages(messages)
->
processMessage(message)
->
cordova.callbackFromNative(callbackId, success, status, [payload], keepCallback);
调用定义好的成功或者失败的JS回调函数。(payload为回传值)

以上就是完整的过程。

参考:
http://blog.devtang.com/blog/2012/03/24/talk-about-uiwebview-and-phonegap/
  • 大小: 8.6 KB
分享到:
评论
4 楼 lq83623 2014-12-18  
WKWebView是iOS8才增加的控件,不过我下载的cordova-ios 最新版3.7.0里面还是使用的时UIWebview。
3 楼 rensanning 2014-12-18  
iOS8版本才有WKWebView,以前的版本都是UIWebView。
2 楼 lq83623 2014-12-17  
楼主,您好, ios的cordova 用的不是 UIWebView 吗?不是WKWebView吧?
1 楼 xf326521 2014-09-12  
了解了

相关推荐

    Cordova 3.x 基础(7) -- Native API的使用

    **Cordova 3.x 基础:Native API的使用** Cordova,作为一个开源的移动应用开发框架,允许开发者使用Web技术(HTML5、CSS3、JavaScript)来构建跨平台的移动应用程序。在Cordova 3.x版本中,开发者可以通过其提供的...

    Cordova 3.x 实用插件(1) -- Google地图Maps

    1. **安装Cordova**:首先,确保你已经在本地环境中安装了Node.js和Cordova。通过运行`npm install -g cordova`命令全局安装Cordova。 2. **创建项目**:使用Cordova创建一个新的项目,例如`cordova create myApp ...

    Cordova 3.x入门

    Cordova允许开发者通过插件系统调用本地API,书中提及了一些常用的lib(库)和框架,如jQuery Mobile和Ionic Framework。 插件开发部分深入探讨了如何为Cordova应用添加自定义功能,这对于想要扩展应用功能的开发者...

    cordova-android-3.0.x.zip

    通过这些测试实例,开发者可以快速掌握PhoneGap的基本用法,如设备API的调用、事件监听、本地存储等。 5. **开发流程**: 开发流程通常包括以下几个步骤: - 安装PhoneGap CLI:首先,开发者需要在开发环境中安装...

    Android应用程序之WebApp开发实战

    1. JavaScriptInterface:Android提供了一个接口,允许JavaScript调用Android原生方法。创建一个实现了`@JavascriptInterface`注解的类,并将其注册到WebView。 2. WebViewClient:自定义`WebViewClient`,重写`...

    ionic 技术分享

    Cordova通过JavaScript访问设备API集,使开发者能够调用如摄像头、罗盘等硬件系统资源。配合上HTML5、CSS3技术的UI框架,开发者可以快速开发跨平台App,而无需编写任何原生代码。然而,打包App时还是需要使用相应...

    android+H5 的jar包

    2. **JavaScript接口**:为了使H5页面能够调用Android的原生功能,我们需要在Java代码中定义JavaScript接口。这些接口会被注入到`WebView`中,H5页面可以通过`window对象`调用这些接口,实现如分享、获取设备信息等...

    Phonegap 2.9.1

    4. **本地资源访问**:PhoneGap允许开发者访问设备的文件系统,存储和读取数据,同时也能调用设备的数据库功能,如SQLite,用于本地数据存储。 5. **事件处理**:PhoneGap 2.9.1支持设备生命周期事件,例如设备就绪...

    tinder-ionic:Tinder 的简单演示

    在这个案例中,JavaScript 负责处理前端逻辑,包括用户交互、数据处理和调用后端API。Ionic 框架基于 AngularJS(Angular的早期版本),一个强大的JavaScript MVC(模型-视图-控制器)框架,用于构建动态Web应用。 ...

    ionic HTML5 移动应用框架 v3.1.0

    4. **Cordova/ Capacitor 支持**:通过集成 Cordova 或 Capacitor,开发者可以调用原生设备的 API,如相机、GPS、蓝牙等,从而实现接近原生应用的功能。 5. **性能优化**:v3.1.0 版本着重优化了渲染速度和资源加载...

Global site tag (gtag.js) - Google Analytics