iOS_WKWebView_原生与JS的交互_可以立刻获取原生返回值

  1. WKWebView系统自带API
    参考:https://blog.csdn.net/baihuaxiu123/article/details/51286109
  2. 使用第三方框架WebViewJavascriptBridge,链接内有详细的使用介绍
    WebViewJavascriptBridge
  3. 以上交互方式都是异步的,JS无法立刻获取原生返回值。现在介绍如何立刻获取原生返回值
    3.1、遵循对应的协议
        _webView.UIDelegate = self;

3.2、实现协议的内容

- (void)webView:(WKWebView *)webView runJavaScriptTextInputPanelWithPrompt:(NSString *)prompt defaultText:(nullable NSString *)defaultText initiatedByFrame:(WKFrameInfo *)frame completionHandler:(void (^)(NSString * __nullable result))completionHandler {
    NSError *err = nil;
    NSData *dataFromString = [prompt dataUsingEncoding:NSUTF8StringEncoding];
    NSDictionary *payload = [NSJSONSerialization JSONObjectWithData:dataFromString options:NSJSONReadingMutableContainers error:&err];
    if (!err){
        NSString *type = [payload objectForKey:@"type"];
        if (type && [type isEqualToString:@"JSbridge"]){
            completionHandler([self getReturnValueWithPayload:payload]);
        }
    }
}
// 自定义方法
- (NSString *)getReturnValueWithPayload:(NSDictionary *)payload{
    NSString *returnValue = @"";
    NSString *functionName = [payload objectForKey:@"functionName"];
    NSDictionary *args = [payload objectForKey:@"arguments"]; // JS传入的值
    if ([functionName isEqualToString:@"getUserData"]) {
        NSDictionary *dictionary = @{@"userCode":@"1231231231" };
        returnValue = [self toJsonWithDictionary:dictionary];
    }
    return returnValue;
}

3.3、 JS调用原生方法

// 声明
function getNativeDataFunction(functionName,parm = {}){
    var payload = {"type": "JSbridge", "functionName": functionName, "arguments": parm};
    return prompt(JSON.stringify(payload));
}
// 调用 nativeData即接收的返回值
var  nativeData =  getNativeDataFunction("getUserData");

你可能感兴趣的:(个人所得,Objective-C)