WKWebView JS交互

本文详细介绍了Objective-C与JavaScript的交互方法,通过WKWebView实现两者之间的消息传递。具体包括配置WKWebView,设置JavaScript调用Objective-C的方法,以及Objective-C调用JavaScript的实现。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

OC与js交互,主要是先知道,谁调用谁的方法,谁实现;

具体实现如下:
#import <JavaScriptCore/JavaScriptCore.h>
@interface JumpWebViewController ()<WKNavigationDelegate,WKUIDelegate,WKScriptMessageHandler>
@property (nonatomic, strong) WKWebView *webView;

—(void)viewDidLoad {
[super viewDidLoad];
// 用于初始化Web视图的配置副本。
WKWebViewConfiguration *config = [[WKWebViewConfiguration alloc] init];
config.preferences = [[WKPreferences alloc] init];
config.preferences.minimumFontSize = 10;
config.preferences.javaScriptEnabled = YES;
config.preferences.javaScriptCanOpenWindowsAutomatically = NO;
config.userContentController = [[WKUserContentController alloc] init];
config.processPool = [[WKProcessPool alloc] init];
self.webView = [[WKWebView alloc] initWithFrame:self.view.bounds
configuration:config];
self.webView.UIDelegate = self;
self.webView.navigationDelegate =self;
[self.view addSubview:self.webView];
[self.webView loadRequest:[NSURLRequest requestWithURL:[NSURL URLWithString:self.urlStr]]];

// 添加js调用oc的方法名
[config.userContentController addScriptMessageHandler:self name:@“gobackForhtml”];
}
#pragma mark - WKScriptMessageHandler
**—(void)userContentController:(WKUserContentController )userContentController didReceiveScriptMessage:(WKScriptMessage )message {
// 实现js调用OC的方法
if ([message.name isEqualToString:@“gobackForhtml”]) {
NSLog(@"%@", message.body);
// OC实现方法
}
}
#pragma mark --------- WKNavigationDelegate --------------
**—(void)webView:(WKWebView )webView didFinishNavigation:(WKNavigation )navigation
{
// OC调用js的方法
NSString * jsStr =[NSString stringWithFormat:@“init(’%@’)”,appString(AppInfoUserToken)];
[self.webView evaluateJavaScript:jsStr completionHandler:^(id _Nullable result, NSError * _Nullable error) {
// js返回值
DLog(@"%@====%@",result,error)
}];
}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值