客户端与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];
    }];

写在最后

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

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

相关阅读更多精彩内容

  • 随着H5技术的兴起,在iOS开发过程中,难免会遇到原生应用需要和H5页面交互的问题。其中会涉及方法调用及参数传值等...
    Chris_js阅读 8,302评论 1 8
  • 最近整理了一下原生与H5之间的交互方式,简单的做个总结。OC端与JS的交互,大致有这几种:拦截协议、JavaScr...
    谈Xx阅读 31,282评论 41 75
  • 前言 关于UIWebView的介绍,相信看过上文的小伙伴们,已经大概清楚了吧,如果有问题,欢迎提问。 本文是本系列...
    CoderLF阅读 12,989评论 2 12
  • 具体参考http://www.liaoxuefeng.com/wiki/0013739516305929606dd...
    hey_前端豆阅读 1,499评论 0 0

友情链接更多精彩内容