写在开头:
客户端在做完基本UI界面之后,往往都会向JS与客户端交互上发展,简单来说就是:客户端调用JS方法,JS调用客户端方法,这样做对app灵活性方面有了极大提升。
网上比较好用的第三方框架很多,比较典型的有webviewJavaScriptBridge
,苹果自iOS7之后推出的一款框架叫JavaScriptCore
JavaScriptCore
是在webview的didFinishLoad里面注入JS语句,完成两端的相互调用,我查过一些资料,对这个框架用着不舒服,于是就转向了webviewJavaScriptBridge
,下面我就着重记录一下自己在开发这块功能时候的笔记和想法。
webviewJavaScriptBridge
兼容iOS6之前和之后,同样也兼容了iOS8推出的WKWebView
,我想用过WKWebView
的人都知道它比之UIWebView
的优势,webviewJavaScriptBridge
能兼容WKWebView
是再好不过了。
往简单了说,webviewJavaScriptBridge
的使用主要是靠WKWebViewJavascriptBridge
来连接OC端(也即客户端)与JS端,这里我们需要配合服务端来做,规定好方法名,调用registerHandler
和callHandler
就可以了。
1. 准备工作
[WKWebViewJavascriptBridge enableLogging];
__weak typeof(self.webView) webview = self.webView;
self.bridge = [WKWebViewJavascriptBridge bridgeForWebView:webview];
[self.bridge setWebViewDelegate:self];
[self.bridge setWebViewDelegate:self];
这个可要可不要,有时候可能需要在webview代理方法中处理一些UI上的显示问题,所以我这里保留了。但是这样的话就可能造成循环引用,因为self持有webview,而webview又持有self,所以我在这里用了weak修饰webview就可以了。
2. OC端调用JS
简单来说,在客户端只需要在合适的地方调用
//JS端执行的方法,也就是在JS中registerHandler的
//data可以为nil,也可以有值,这个看JS端需要
//responseData是JS执行完方法后返回给客户端的数据,如果客户端在调用JS方法后还有后续逻辑处理,就可以用这个数据,比如客户端点击原生的Button去登陆,登陆放在JS执行,客户端还需要拿到登陆结果,这时候就可以用这个了(这个例子不恰当,因为登陆一般是放在客户端,明白就好哈)
[self.bridge callHandler:@"JS端resigterHandler的方法" data:nil responseCallback:^(id responseData) {
//根据返回结果客户端做相应处理(如果需要的话)
}];
3. JS调用OC
//将token值传给JS
//这个是JS中callHandler方法,JS端触发后会回调到这里
//其实实现原理和上面相同,如果JS需要客户端返回结果做相应操作,在block块里面返回给所需要的参数就可以了
//这个方法中客户端没有做实际的处理,只是传给了JS相应的参数
[self.bridge registerHandler:@"JS中CallHandler的方法" handler:^(id data, WVJBResponseCallback responseCallback) {
NSString *url = data[@"url"];
responseCallback([weakSelf paramsOfNativeRequestResponse:url]);
}];
//跳转到登录界面
//这个是JS端触发方法后,OC端去实现,这里没有返回值,直接处理了其他逻辑
[self.bridge registerHandler:@"JS中CallHandler的方法" handler:^(id data, WVJBResponseCallback responseCallback) {
[[YGReference shareInstance] showLoginView];
}];
写在最后
两端的调用总体来说就是这样,是不是很方便呢?注意要和前端同事协调好方法名