美文网首页iOS Developer
客户端与JS交互

客户端与JS交互

作者: 皮乐皮儿 | 来源:发表于2017-08-22 16:28 被阅读929次

    写在开头:

    客户端在做完基本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交互

        本文链接:https://www.haomeiwen.com/subject/fueldxtx.html