iOS - WKWebView与JS之间的交互
一、前言
这个星期面临一个网页的需求,需要用到这方面的知识,很久没看过这方面的代码了,记录下吧。
wkwebview的创建和使用就不再提及了,直接看与JS之间的交互吧。
二、内容
1、JS调用OC
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。
2、OC调用JS
// 调用API方法 [self.weexWebView evaluateJavaScript:@“JS” completionHandler:^(id object, NSError * _Nullable error) { NSLog(@"obj:%@---error:%@", object, error); }];
目前需要用到的东西就这么多了,等到具体的JS代码给到的时候再去调试吧。
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 开发者必知的日志记录最佳实践
· SQL Server 2025 AI相关能力初探
· Linux系列:如何用 C#调用 C方法造成内存泄露
· AI与.NET技术实操系列(二):开始使用ML.NET
· 记一次.NET内存居高不下排查解决与启示
· Manus重磅发布:全球首款通用AI代理技术深度解析与实战指南
· 被坑几百块钱后,我竟然真的恢复了删除的微信聊天记录!
· 没有Manus邀请码?试试免邀请码的MGX或者开源的OpenManus吧
· 【自荐】一款简洁、开源的在线白板工具 Drawnix
· 园子的第一款AI主题卫衣上架——"HELLO! HOW CAN I ASSIST YOU TODAY