Phonegap 通信原理

简介:

下图为JavaScript调用本地代码的通信过程

Phonegap的核心API都是基于插件的,这些JavaScript API都会调用cordova.exec() 函数来完成操作。cordova.exec()函数如下

cordova.exec(success, fail, service, action, args);

其中success是操作成功后的回调函数

fail是操作失败后的回调函数

service是所要操作的本地服务名称

action是要执行的服务的具体操作

args是操作所需要的参数

 

在cordova.exec() 函数中,实现JavaScript到本地代码通信的关键代码为:

1
2
3
exec:  function (bridgeSecret, service, action, callbackId, argsJson) {
       return  prompt(argsJson,  'gap:' +JSON.stringify([bridgeSecret, service, action, callbackId]));
   },

 

prompt函数本身为浏览器用来提示用户输入信息的。 但是实际上并没有,原因是浏览器做过处理。

在Android中,用到SystemWebChromeClient类,会覆盖WebChromeClient的onJsPrompt方法。这个函数就是用来处理JavaScrpt的prompt函数的请求

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
@Override
public  boolean  onJsPrompt(WebView view, String origin, String message, String defaultValue,  final  JsPromptResult result) {
     // Unlike the @JavascriptInterface bridge, this method is always called on the UI thread.
     String handledRet = parentEngine.bridge.promptOnJsPrompt(origin, message, defaultValue);
     if  (handledRet !=  null ) {
         result.confirm(handledRet);
     else  {
         dialogsHelper.showPrompt(message, defaultValue,  new  CordovaDialogsHelper.Result() {
             @Override
             public  void  gotResult( boolean  success, String value) {
                 if  (success) {
                     result.confirm(value);
                 else  {
                     result.cancel();
                 }
             }
         });
     }
     return  true ;
}

  里面调用promptOnJsprompt方法

1
2
3
4
public  String promptOnJsPrompt(String origin, String message, String defaultValue) {
                String r = jsExec(bridgeSecret, service, action, callbackId, message);
                ...   
    }

  在jsExec里调用

pluginManager.exec(service, action, callbackId, arguments);

至此Js到本地通信完成

 

参考

Android JSBridge的原理与实现

PhoneGap插件调用Java流程源码分析



本文转自Work Hard Work Smart博客园博客,原文链接:http://www.cnblogs.com/linlf03/p/7084774.html,如需转载请自行联系原作者

目录
相关文章
|
7月前
|
物联网 数据管理
HarmonyOS学习路之开发篇—网络与连接(蓝牙开发 一)
蓝牙是短距离无线通信的一种方式,支持蓝牙的两个设备必须配对后才能通信。HarmonyOS蓝牙主要分为传统蓝牙和低功耗蓝牙(通常称为BLE,Bluetooth Low Energy)。传统蓝牙指的是蓝牙版本3.0以下的蓝牙,低功耗蓝牙指的是蓝牙版本4.0以上的蓝牙。
|
7月前
|
物联网 数据管理 API
HarmonyOS学习路之开发篇—网络与连接(蓝牙开发 二)
通过BLE扫描和广播提供的开放能力,可以根据指定状态获取外围设备、启动或停止BLE扫描、广播。
|
9月前
|
安全 Go
gRPC实现简单通讯 | 青训营笔记
gRPC实现简单通讯 | 青训营笔记
93 0
|
JSON 小程序 JavaScript
微信小程序开发实战(宿主环境与通信模型)
微信小程序开发实战(宿主环境与通信模型)
微信小程序开发实战(宿主环境与通信模型)
|
存储 网络协议 Unix
应用实战精解系列(七):RVB2601以太网通讯测试
芯片开放社区(OCC)面向广大开发者推出应用实战系列内容,通过分享开发者实战开发案例,总结应用开发经验,梳理开发中的常见问题及解决方案,为后续参与的开发者提供更多参考与借鉴。
485 0
应用实战精解系列(七):RVB2601以太网通讯测试
|
Web App开发 移动开发 前端开发
如何用 Electron + WebRTC 开发一个跨平台的视频会议应用
在搭建在线教育、医疗、视频会议等场景时,很多中小型公司常常面临 PC 客户端和 Web 端二选一的抉择。Electron 技术的出现解决了这一难题,只需前端开发就能完成一个跨平台的 PC 端应用。本文主要介绍使用 Electron + WebRTC 搭建跨平台的视频会议应用的技术方案。
如何用 Electron + WebRTC 开发一个跨平台的视频会议应用
|
移动开发 开发框架 前端开发