WKWebView JS交互

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)
}];
}

猜你喜欢

转载自blog.csdn.net/heqiang2015/article/details/84325171