客户端与JS交互

写在开头:

客户端在做完基本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端,这里我们需要配合服务端来做,规定好方法名,调用registerHandlercallHandler就可以了。

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];
    }];

写在最后

两端的调用总体来说就是这样,是不是很方便呢?注意要和前端同事协调好方法名

你可能感兴趣的:(客户端与JS交互)