内容简介:每次想写点东西,但总是觉得心中有千万种骚操作,就是手跟不上大脑。别说了又要超鬼被举报了。今天还是决定整理下最近的笔记了。先从JsBridge 通信耗时测试开始吧。下面统称JsB。之前hybrid项目中遇到过一个卡顿问题,现象是当JsB传递数据越大时页面就越容易出现卡顿。一时间以为是原生部分 因,于是通过断点发现,其实卡顿发生在原生接受到JsB消息之前,也就是说是在H5部分或者JsB处理部分,由于自己前端刚入门,还特意去咨询项目中的前端同事,可能是问题说的不清楚,最终估计是以为我在给他找问题,结果就直接说前
每次想写点东西,但总是觉得心中有千万种骚操作,就是手跟不上大脑。别说了又要超鬼被举报了。
今天还是决定整理下最近的笔记了。先从JsBridge 通信耗时测试开始吧。下面统称JsB。
正文
之前hybrid项目中遇到过一个卡顿问题,现象是当JsB传递数据越大时页面就越容易出现卡顿。一时间以为是原生部分 因,于是通过断点发现,其实卡顿发生在原生接受到JsB消息之前,也就是说是在H5部分或者JsB处理部分,由于自己前端刚入门,还特意去咨询项目中的前端同事,可能是问题说的不清楚,最终估计是以为我在给他找问题,结果就直接说前端只有业务不会造成卡顿。 [图片]
所以让我想起了那句话,Talk is cheap.show me the code.
JsB通信的三个部分,先看看JSB消息传递的调用顺序。
Native 调 JS
上图为安卓的调用顺序。 iOS的其实也没什么差别,只是对应的原生接口名称不一样而。 WebviewJavaScriptBridge 原理图.png
图画的很丑,将就看吧。
加入埋点
从上图看到各个部分的调用顺序。所以,我们先看看JS调Native的耗时。
JS部分的时间
onclick() 到 JsB的doSend()方法,因为这部分都是JS代码,只要在onclick()时给window对象加一个属性window.JSTime记录触发onclick()的瞬时间,然后再JsB的doSend()函数中当前时间减去window.JSTime就是JS部分的时间。 JsB部分时间
doSend()到原生接受到第一条消息也就是触发webview的- (void)webView:(WKWebView *)webView decidePolicyForNavigationAction:(WKNavigationAction *)navigationAction decisionHandler:(void (^)(WKNavigationActionPolicy))decisionHandler (本人用的WKWebview,如果是UIWebview自己找下回调函数)
- (void)webView:(WKWebView *)webView decidePolicyForNavigationAction:(WKNavigationAction *)navigationAction decisionHandler:(void (^)(WKNavigationActionPolicy))decisionHandler { if (webView != _webView) { return; } NSURL *url = navigationAction.request.URL; __strong typeof(_webViewDelegate) strongDelegate = _webViewDelegate; if ([_base isWebViewJavascriptBridgeURL:url]) { if ([_base isBridgeLoadedURL:url]) { [_base injectJavascriptFile]; } else if ([_base isQueueMessageURL:url]) { [self WKFlushMessageQueue]; } else { [_base logUnkownMessage:url]; } decisionHandler(WKNavigationActionPolicyCancel); return; } if (strongDelegate && [strongDelegate respondsToSelector:@selector(webView:decidePolicyForNavigationAction:decisionHandler:)]) { [_webViewDelegate webView:webView decidePolicyForNavigationAction:navigationAction decisionHandler:decisionHandler]; } else { decisionHandler(WKNavigationActionPolicyAllow); } } 复制代码
但是我们查看WebViewJavascriptBridge源码发现,在触发原生回调后,webview还是继续调JsB的WebViewJavascriptBridge._fetchQueue()。所以JsB部分的时间,只需要在doSend()给window添加一个埋点window.JsBTime,然后在_fetchQueue()return的前面一行获取瞬时时间减去window.JsBTime就是JsB的消耗时间啦。
原生部分
部分就忽略了,使用CFAbsoluteTimeGetCurrent() 做代码执行时间测试相对更加准确。
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持 码农网
猜你喜欢:- 网络通信2:TCP简单通信
- 网络通信3:TCP交互通信
- 解惑3:时间频度,算法时间复杂度
- 总是感觉时间不够用?程序员如何管理时间?
- TNB开创“数字时间”,让“时间就是金钱”成为可能
- 如何在ASP.NET Core中使用SignalR构建与Angular通信的实时通信应用程序
本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们。
PHP for the World Wide Web, Second Edition (Visual QuickStart Gu
Larry Ullman / Peachpit Press / 2004-02-02 / USD 29.99
So you know HTML, even JavaScript, but the idea of learning an actual programming language like PHP terrifies you? Well, stop quaking and get going with this easy task-based guide! Aimed at beginning ......一起来看看 《PHP for the World Wide Web, Second Edition (Visual QuickStart Gu》 这本书的介绍吧!