1. 程式人生 > >iOS中原生APP與JS互動 之 WebViewJavascriptBridge 的簡單用法

iOS中原生APP與JS互動 之 WebViewJavascriptBridge 的簡單用法

有時候我們需要跟H5介面做一些簡單的互動功能,這就需要跟JS打交道了。

1、首先初始化一個webview(viewdidload)

UIWebView* webView = [[UIWebView alloc] initWithFrame:self.view.bounds];
[self.view addSubview:webView];

2、關聯webview與WebViewJavascriptBridge

[WebViewJavascriptBridge enableLogging];

_bridge = [WebViewJavascriptBridge bridgeForWebView:webView webViewDelegate:self handler:^(id data, WVJBResponseCallback responseCallback) {
NSLog(@"
ObjC received message from JS: %@", data); responseCallback(@"Response for message from ObjC"); }];

3、下面就是原生APP與JS 的互動了

3.1、js調oc方法

/**
     *   js調oc方法(可以通過data給oc方法傳值,使用responseCallback將值再返回給js)
     *
     *  @param data             從H5傳值給原生OC
     *  @param responseCallback 使用responseCallback將值再返回給js
     *
     *  @return
     */


[_bridge registerHandler:@"testObjcCallback" handler:^(id data, WVJBResponseCallback responseCallback) {
        NSLog(@"testObjcCallback called: %@", data);
        responseCallback(@"Response from testObjcCallback");
    }];

這裡注意testObjcCallback這個方法的標示(切記這個是個Key不是方法名(自己糾結半天沒資料))。html那邊的命名要跟ios這邊相同,才能調到這個方法。當然這個名字可以兩邊商量著自定義。簡單明確即可。

3.2、oc調js方法(通過data可以傳值,通過 response可以接受js那邊的返回值

/**
         *  oc調js方法(通過data可以傳值,通過 response可以接受js那邊的返回值 )
         *
         *  @param data     OC原生傳給JS值
         *  @param response js返回的資料
         *
         *  @return
         */

id data = @{ @"greetingFromObjC": @"Hi there, JS!" };
    [_bridge callHandler:@"testJavascriptHandler" data:data responseCallback:^(id response) {
        NSLog(@"testJavascriptHandler responded: %@", response);
    }];
 注意這裡的 testJavascriptHandler也是個方法標示。

3.3、oc給js傳值(通過 response接受返回值

[_bridge send:@"A string sent from ObjC to JS" responseCallback:^(id response) {
        NSLog(@"sendMessage got response: %@", response);
    }];
3.4、oc給js傳值(無返回值)
[_bridge send:@"A string sent from ObjC after Webview has loaded."];