iOS开发APP开发iOS Development

App与Js交互(一)iOS

2018-02-07  本文已影响672人  gwpp

目录

示例代码

Demo: https://github.com/gwpp/jsinterface

前言

不论是在创业团队中快速试错,还是在成熟团队中快速迭代复杂需求,还或者是其他原因,WebView在APP中的大量使用已经成为了一个明显的趋势,这也应该算是大前端融合的一个表象吧。笔者在工作中也遇到过很多App&Js交互的问题,粗浅的研究了一下,这里也分享给大家,如果有错误的地方还请下方留言指出,共同进步。

iOS系统中的交互

众所周知,iOS有UIWebViewWKWebView两个组件可以用来渲染嵌入页面。前者使用甚广,出生的也早,后者是iOS8推出的,优化了加载速度和内存,安全性上也有所提升。具体的两者比较百度、简书上都很多,这里不做赘述。

方案一,拦截跳转

方案二,拦截跳转

阶段小结

前两种方法到此就介绍完了,很简单,但是在项目大了之后拦截跳转的代理方法中会有非常多的判断。冗余、可维护性差,硬编码重。所以我们会有下面的其他方法。

方案三,JSContext

JSContext即JavaScriptContext,这个东西在UIWebView中可以拿到,但是在WKWebView中却是取不到了,所以只能用在UIWebView中。除此以外Android里也有类似的一个东西,所以使用JSContext就有了在JS端多平台统一的可能,这里不多说,在《App与Js交互(三)》中会有详细说明。
JSContext的原理就是iOS暴露出去一个遵守<JSExport>协议的对象给JS,JS可以直接调用该对象的public方法。

方案四,WebKit

window.webkit.messagehandlers.<name>.postMessage是apple推荐使用的WKWebView的JS交互方式,使用起来比较简单,不支持callback回调。

方案五,JsBridge

上一篇下一篇

猜你喜欢

热点阅读