专栏首页吴裕超js和native交互方法浅析

js和native交互方法浅析

一、背景

最近接触公司项目,需要和原生app做交互,由此业务需求,开始了学习探索之路。

二、解决方案之WebViewJavascriptBridge 

想要和app交互,必须在app上先把bridge进行实例化,这是先决条件。

oc解决方案

步骤

1、引入文件

#import "WebViewJavascriptBridge.h"

2、实例化WebViewJavascriptBridge 

self.bridge = [WebViewJavascriptBridge bridgeForWebView:webView];

3、在oc中注册一个函数,并调用一个js处理函数 

[self.bridge registerHandler:@"ObjC Echo" handler:^(id data, WVJBResponseCallback responseCallback) {
    NSLog(@"ObjC Echo called with: %@", data);
    responseCallback(data);
}];
[self.bridge callHandler:@"JS Echo" data:nil responseCallback:^(id responseData) {
    NSLog(@"ObjC received response: %@", responseData);
}];

4、把这段js代码放入前端js或者页面中 

 1 function setupWebViewJavascriptBridge(callback) {
 2     if (window.WebViewJavascriptBridge) { return callback(WebViewJavascriptBridge); }
 3     if (window.WVJBCallbacks) { return window.WVJBCallbacks.push(callback); }
 4     window.WVJBCallbacks = [callback];
 5 // 创建iframe 对象, 在网页中,iframe的用法非常多,主要应用于伪ajax、嵌套页面、页面重用。
 6     var WVJBIframe = document.createElement('iframe');
 7     WVJBIframe.style.display = 'none';
 8     WVJBIframe.src = 'https://__bridge_loaded__';
 9     document.documentElement.appendChild(WVJBIframe);
10 //保证前面的代码执行完再删除这个iframe节点,
11 //setTimeout (fn,0)
12 //同步代码转异步代码,这是为了手动调配优先级不高的代码靠后执行。保证当前处于事件队列中的任务全部执行完后该任务(函数)立刻得到执行。
13     setTimeout(function() { document.documentElement.removeChild(WVJBIframe) }, 0)
14 }

5、在前端调用

setupWebViewJavascriptBridge(function(bridge) {
    
    /* Initialize your app here */

    bridge.registerHandler('JS Echo', function(data, responseCallback) {
        console.log("JS Echo called with:", data)
        responseCallback(data)
    })
    bridge.callHandler('ObjC Echo', {'key':'value'}, function responseCallback(responseData) {
        console.log("JS received response:", responseData)
    })
})

API

oc调用js

// OC端 向 JS端 传数据的回调函数, 注册 registerHandler(标识符, 数据回调闭包), 当OC端发起数据传送,会调用 function(数据, OC端给的回调函数) --------->handlerName要和OC端保持一致

js调用oc

bridge.callHandler("handlerName", data)

总结

交互前需要先对OC环境和JS环境进行初始化,JS环境的初始化通过Web页面加载时发送特定的URL来完成。

WebViewJavascriptBridge在OC端和JS端各自维护一个bridge对象来保存开放给另一端的方法,以及自身调用另一端后的回调方法。前者通过handlerName来映射,后者通过callBackId标识唯一性。方法调用时必定携带handlerName,若需要回调,还需携带callBackId。

WebViewJavascriptBridge中OC调用JS采用的是WebView提供的JS执行方法;而JS调用OC采用的是URL拦截的方式,OC端通过识别特定的URL来区分是否需要拦截,并做相应的逻辑处理。

android解决方案

安卓版插件传送门https://github.com/gzsll/WebViewJavascriptBridge,原理基本一致,没有深入研究。

思考

WebViewJavascriptBridge还需要做IOS和Android的兼容,那么,还有没有更好的方案呢?功夫不负有心人,我找到了DSBridge

三、解决方案之DSBridge

dsbridge最大的特点就是支持同步!中文文档传送门:https://github.com/wendux/DSBridge-Android/blob/master/readme-chs.md

文章写的比较浅,如有纰漏,欢迎指正,如果有更好方案,欢迎留言。

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

我来说两句

0 条评论
登录 后参与评论

相关文章

  • 大型vue单页面项目优化总结

    这是之前在公司oa项目优化时罗列的优化点,基本都已经完成,当时花了点心思整理的,保存在这里,方便以后其他项目用到查漏补缺。 1、打包文件中的app.js文件放入...

    吴裕超
  • js设计模式之惰性单例模式

    <html> <body> <button id="loginBtn">登录</button> </body> <script> var cr...

    吴裕超
  • win10 安装flutter记录

    2、配置环境变量,这里我本来想试试配成本地位置,结果到后来运行时候跑不起来,无奈最后还是按官网的来,当前用户新增PUB_HOSTED_URL和FLUTTER_S...

    吴裕超
  • C# 判断两条直线距离

    d= \frac{ \left| C_1-C_2 \right|}{\sqrt{A^2+B^2}}

    林德熙
  • django AJAX 的应用

    郭楷丰
  • 【行业】苹果和IB将通过新的机器学习集成展开合作

    AiTechYun 编辑:nanan ? 周一晚些时候,苹果和IBM宣布扩大现有合作伙伴关系,允许客户通过苹果的Core ML和IBM的Watson(沃森)技术...

    AiTechYun
  • boostrap4浅谈之js插件(二)

    在boostrap4入门之js插件的第一部分中,我们已经了解了下拉菜单,手风琴,选项卡,响应式导航栏等插件,在这一篇,我们主要是了解以下几个插件,具体示例如下:

    邂逅千寻
  • ElasticSearch未授权访问漏洞修复方案

    您好,近日,腾讯云安全中心情报侧监控显示,目前云上部分用户ElasticSearch服务器仍然存在的未授权安全漏洞,黑客可利用此类漏洞发起勒索攻击,会导致您的服...

    Chad
  • WordPress代码显示查询次数/加载时间/内存占用

    performance的参数 ture 表示在页面前端显示。如果你想在页面中不显示,只在html源码中可见可改为 false!

    空木白博客
  • 为什么有些人总是觉得国产办公软件WPS比不上微软

    wps是中国曾经的第一代程序员求伯君的杰作,在中国软件孩子稀薄区的年代能够有wps这种软件出现已经是奇迹般的存在了,由于早期的程序员对于软件生态理解不彻底,所以...

    程序员互动联盟

扫码关注云+社区

领取腾讯云代金券