浅谈JS与OC相互调用并传参(一)

前几天忙着微信支付,这几天刚刚抽出时间写一写之前在工作中研究的JS调用OC方法,还有就是OC给JS传值.我之前工作在APP中加入一个WebView,但是在APP中登录的同时也要在WebView中同时登陆,我们研究了一个方法就是把token/model/手机类型(iOS或Android)/ 同时在js中根据token是否为NULL,来调用APP的登录方法.

JS与OC相互相互调用,我知道的是有三种方法

1.WebViewJavascriptBridge(第三方) 2.WKWebView(据说以后要代替WebView) 3.JSExport(JavaScrptCore框架) 4.webView shouldStartLoadWithRequest:中截取JS传过来的URL调用方法并传值.
**
博主用的则是最后一种和"JSExport".先主要讲一下JSExport的用法吧.
首先需求是,我要把我这边的token.model.和设备信息传给JS
**


**
首先添加JavaScriptCore.framework框架
**

添加JavaScriptCore框架

**
导入头文件
**
import <JavaScriptCore/JavaScriptCore.h>
**
加载本地HTML
**

    NSString *basePath = [[NSBundle mainBundle]bundlePath];
    NSString *helpHtmlPath = [basePath stringByAppendingPathComponent:@"GroupPay.html"];
    NSURL *url = [NSURL fileURLWithPath:helpHtmlPath];    
    [_webView loadRequest:[NSURLRequest requestWithURL:url]];

**
在 webViewDidFinishLoad:(UIWebView *)webView调用(前提要给webView加代理)
**


-(void)webViewDidFinishLoad:(UIWebView *)webView
{
    
    if ([BNCUserDefault objectForKey:@"token"] == nil) {
        NSString *token = @"null";
        NSString *model = @"null";
        NSString *ios = @"ios";
        JSValue *picCallback = self.context[@"picCallback"];
        [picCallback callWithArguments:@[token,model,ios]];
    } else {
        NSString *token = [[NSUserDefaults standardUserDefaults] objectForKey:@"token"];
        NSString *model =[BNCUserDefault objectForKey:@"model"];
        NSString *ios = @"ios";
        JSValue *picCallback = self.context[@"picCallback"];
        [picCallback callWithArguments:@[token,model,ios]];

    }

**
在JS端是这样写的
**



  
                 var picCallback = function(token,model,app) {
                     alert(token);
                     alert(model);
                     alert(app);
                }

**
我们运行一下看一下效果
**

token的alert
model的alert
设备信息

**
接下来我使用一种方法调用JS的方法并返回给参数
**



self.context[@"model"] = ^() {
        NSLog(@"调用model的方法");
        NSString *model =[BNCUserDefault objectForKey:@"model"];
       return model;
}

**
在JS端我是这样写的
**

        var a = model();
        alert(a);
        
Paste_Image.png

但这个也会有个问题:问题是这个在网页加载之后我们会把这个值传给JS,但是JS是要在加载网页过程中拿到这些值,所以在调用中往往会获得一个nil.然而这个问题困扰我好久,最后只能在JS端加了一个延迟加载,这个会对速度和用户体验会有影响的.好先写到这吧

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值