iOS与js互调

2018-09-13  本文已影响0人  dequal

项目中经常遇到App与h5互相调用的情形,这里分享一下经验(此处iOS用到的是WKWebView).

1.iOS调js

- (void)viewDidLoad {
    [super viewDidLoad];

    NSString *methodName;
    NSString *paraStr;
    [self.webView evaluateJavaScript:[NSString stringWithFormat:@"%@('%@')",methodName,paraStr] completionHandler:^(id _Nullable data, NSError * _Nullable error) {
        NSLog(@"");
    }];
    
    //webView设置
    WKUserContentController *controller = [[WKUserContentController alloc] init];
    WKWebViewConfiguration *configuration = [[WKWebViewConfiguration alloc] init];
    configuration.userContentController = controller;
    self.webView = [[WKWebView alloc]initWithFrame:self.view.bounds configuration:configuration];
    
    //注册 JS交互事件 (注意注册一定要写在viewDidLoad里面,写在viewDidAppear等方法里面在低版本调起本地相册时会出现问题)
    [self.webView.configuration.userContentController addScriptMessageHandler:self name:@"MKAPPWebViewRecommendJavascriptBridge"];
}
- (void)dealloc {
    //销毁写在dealloc
    [self.webView.configuration.userContentController removeAllUserScripts];
}
注意:

weiView执行JS代码时,总是没有效果,可是方法名与参数都没有错,代码如下:

[webView stringByEvaluatingJavaScriptFromString:[NSString stringWithFormat:@"%@('%@')", methodName, paraStr]];

其中字符串paraStr格式如下:

         {
            "serverId" : "1110",
            "roleId" : "1001",
            "roleVip" : "A",
            "appUId" : "100702140113",
            "roleName" : "王者荣耀",
            "roleLevel" : "A",
            "serverName" : "腾讯游戏"
          }

字符串为啥是这种怪格式呢?请继续往下看。。。
这个paraStr就是一个标准的Json串,实现方法如下:

+ (NSString*)getJsonWith:(NSDictionary*)dic {
    NSString *json = nil;
    if ([NSJSONSerialization isValidJSONObject:dic]) {
        NSError *error;
        NSData *jsonData = [NSJSONSerialization dataWithJSONObject:dic options:NSJSONWritingPrettyPrinted error:&error];
        if(!error) {
            json =[[NSString alloc] initWithData:jsonData encoding:NSUTF8StringEncoding];
        }else {
            NSLog(@"JSON parse error: %@", error);
        }
    }else {
        NSLog(@"Not a valid JSON object: %@", dic);
    }
    
    return json;
   }

之所以json串是那种怪格式,是因为[NSJSONSerialization dataWithJSONObject:dic options:NSJSONWritingPrettyPrinted error:&error];中的options是NSJSONWritingPrettyPrinted,苹果官网资料是这样说的“为了使打印出来的json串格式标准一些,添加了一些空格符号”。

发现之所以js代码不执行,是因为json串格式的问题,后来我将options改为 0,现在再来看一看json串的样子吧: {"serverId":"1110","roleId":"1001","roleVip":"A","appUId":"100702140113","roleName":"王者荣耀","roleLevel":"A","serverName":"腾讯游戏"}。 现在,才有一个字符串的样子嘛!此时我的js执行效果也可以看到了!

2.js调iOS

附带一种js调用iOS的方法:

    /**
     js调iOS的方法
     
     @param APPWebViewJSBridge 协议名 : iOS这边监听到的为message.name
     @param APPPara            参数   : iOS这边监听到的为message.body
     */
    //    window.webkit.messageHandlers.APPWebViewJSBridge.postMessage('APPPara');
上一篇下一篇

猜你喜欢

热点阅读