Подтвердить что ты не робот

Как получить JSContext из WKWebView

В UIWebView я могу получить JSContext через:

[webView valueForKeyPath:@"documentView.webView.mainFrame.javaScriptContext"]

То же самое не работает в WKWebView и при сбоях приложения, когда он поступает в эту строку кода.

Есть ли способ получить JSContext в WKWebView?

заблаговременно.

4b9b3361

Ответ 1

Вы не можете получить контекст, потому что макет и javascript обрабатываются другим процессом.

Вместо этого добавьте скрипты в конфигурацию вашего веб-браузера и установите в качестве обработчика сообщения script контроллер вида (или другой объект).

Теперь отправьте сообщения с JavaScript так:

window.webkit.messageHandlers.interOp.postMessage(message)

Ваш обработчик сообщения script получит обратный вызов:

- (void)userContentController:(WKUserContentController *)userContentController 
                            didReceiveScriptMessage:(WKScriptMessage *)message{
    NSLog(@"%@", message.body);
}

Ответ 2

настройте свой wkwebview таким образом и добавьте обработчик соответственно и опубликуйте сообщение из script в аналогичном шаблоне

NSString *myScriptSource = @"alert('Hello, World!')";


WKUserScript *s = [[WKUserScript alloc] initWithSource:myScriptSource injectionTime:WKUserScriptInjectionTimeAtDocumentStart forMainFrameOnly:YES];
WKUserContentController *c = [[WKUserContentController alloc] init];
[c addUserScript:s];
// Add a script message handler for receiving  "buttonClicked" event notifications posted from the JS document using window.webkit.messageHandlers.buttonClicked.postMessage script message
[c addScriptMessageHandler:self name:@"buttonClicked"];

WKWebViewConfiguration *conf = [[WKWebViewConfiguration alloc] init];
conf.userContentController = c;

WKWebView *webview = [[WKWebView alloc] initWithFrame:self.view.bounds configuration:conf];
[self.view addSubview:webview];
webview.autoresizingMask = UIViewAutoresizingFlexibleWidth | UIViewAutoresizingFlexibleHeight;
// Do any additional setup after loading the view, typically from a nib.
NSURLRequest *request = [NSURLRequest requestWithURL:[NSURL URLWithString:@"http://google.com"]];
[webview loadRequest:request];

реализовать script обработчик сообщений "WKScriptMessageHandler" с именем метода

#pragma mark -WKScriptMessageHandler
- (void)userContentController:(WKUserContentController *)userContentController didReceiveScriptMessage:(WKScriptMessage *)message          {
if ([message.name isEqualToString:@"buttonClicked"]) {
self.buttonClicked ++;
}

// JS objects are automatically mapped to ObjC objects
id messageBody = message.body;
if ([messageBody isKindOfClass:[NSDictionary class]]) {
NSString* idOfTappedButton = messageBody[@"ButtonId"];
[self updateColorOfButtonWithId:idOfTappedButton];
}
}

и опубликуйте форму сообщения js, как этот

var button = document.getElementById("clickMeButton");
button.addEventListener("click", function() {
    var messgeToPost = {'ButtonId':'clickMeButton'};
    window.webkit.messageHandlers.buttonClicked.postMessage(messgeToPost);
},false);

Ответ 3

XWebView - хорошее решение для вашей проблемы. Он может установить мост между native и JS и предоставить интерфейс API с интерфейсом.