1、前言前端
這個星期面臨一個網頁的需求,須要用到這方面的知識,好久沒看過這方面的代碼了,記錄下吧。web
wkwebview的建立和使用就再也不說起了,直接看與JS之間的交互吧。weex
2、內容post
一、JS調用OClua
window.webkit.messageHandlers.<#對象名#>.postMessage(<#參數#>)
//進行配置控制器 WKWebViewConfiguration *configuration = [[WKWebViewConfiguration alloc] init]; //實例化對象 configuration.userContentController = [WKUserContentController new]; //調用JS方法 [configuration.userContentController addScriptMessageHandler:self name:@"actionEnd"];
#pragma mark - WKScriptMessageHandler - (void)userContentController:(WKUserContentController *)userContentController didReceiveScriptMessage:(WKScriptMessage *)message { if ([message.name isEqualToString:@"actionEnd"]) { NSDictionary *jsData = message.body; NSLog(@"%@", message.name, jsData); } }
注:對象名要和前端溝通好。前端JS能回傳的類型只能是 NSNumber, NSString, NSDate, NSArray, NSDictionary, NSNull。spa
二、OC調用JS調試
// 調用API方法 [self.weexWebView evaluateJavaScript:@「JS」 completionHandler:^(id object, NSError * _Nullable error) { NSLog(@"obj:%@---error:%@", object, error); }];
目前須要用到的東西就這麼多了,等到具體的JS代碼給到的時候再去調試吧。code