IOS-WebViewJavascriptBridge使用說明


 下面來說一下WebViewJavascriptBridge在ios端怎么樣使用。

 首先確保一份已經配好功能的html文件。

 1.初始化一個webview(viewdidload)

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

 2.將此webview與WebViewJavascriptBridge關聯(viewdidload)

if (_bridge) { return; }  [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");  }];

 ps:此時你的webview就與js搭上橋了。下面就是方法的互調和參數的互傳。

 (1) js調oc方法(可以通過data給oc方法傳值,使用responseCallback將值再返回給js)

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

  這里注意testObjcCallback這個方法的標示。html那邊的命名要跟ios這邊相同,才能調到這個方法。當然這個名字可以兩邊商量着自定義。簡單明確即可。

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

id data = @{ @"greetingFromObjC": @"Hi there, JS!" }; [_bridge callHandler:@"testJavascriptHandler" data:data responseCallback:^(id response) { NSLog(@"testJavascriptHandler responded: %@", response); }];

 注意這里的  testJavascriptHandler也是個方法標示。

 (3)oc給js傳值(通過  response接受返回值 )

[_bridge send:@"A string sent from ObjC to JS" responseCallback:^(id response) { NSLog(@"sendMessage got response: %@", response); }];

  (4)oc給js傳值(無返回值)

[_bridge send:@"A string sent from ObjC after Webview has loaded."];


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM