Phonegap 通信原理

Posted work hard work smart

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了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到本地代码通信的关键代码为:

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

 

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

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

    @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方法

 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流程源码分析

 

以上是关于Phonegap 通信原理的主要内容,如果未能解决你的问题,请参考以下文章

在tablayout片段之间进行通信[重复]

与另一个片段通信的片段接口

无法通过接口获取与片段通信的活动

你可能不知道的JavaScript代码片段和技巧(下)

你可能不知道的JavaScript代码片段和技巧(上)

Javascript 和 Phonegap 插件之间的异步通信