android webview & ios uiwebview和wkwebview的交互以及本地缓存

android webview

js调用java的方式

1.java通过注解@JavascriptInterface导出方法, js通过window.别名.方法名调用方法

2.拦截url方式,通过shouldOverrideUrlLoading实现


java调用js的方式

1.webview.loadUrl, 可以通过回调实现获取返回值

2.webview.evaluateJavascript 4.4及以上版本才能使用

3.通过反射实现stringByEvaluatingJavaScriptFromString方法


离线缓存

通过shouldInterceptRequest来实现



IOS UIWebview

js调用objc

1.拦截url方式,webview:shouldStartLoadWithRequest:navigationType

2.通过JavascriptCore实现


objc调用js

1.stringByEvaluatingJavaScriptFromString

2.JavaScriptCore


离线缓存

通过NSURLProtocol拦截请求

https://github.com/marcuswestin/WebViewProxy

https://developer.apple.com/library/content/samplecode/CustomHTTPProtocol/Introduction/Intro.html

http://draveness.me/intercept/



IOS WKWebview

js调用objc

1.拦截url方式,通过webview:decidePolicyForNavigationAction:decisionHandler实现

2.MessageHandler


objc调用js

1.evaluateJavaScript:completionHandler


离线缓存

通过NSURLProtocol拦截请求

https://github.com/yeatse/NSURLProtocol-WebKitSupport


其它

jsbridge和webviewjavascriptbridge本质上就是拦截url方式来实现的。



  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值