js iso 交互

1iOS调用js 

- (void)webViewDidFinishLoad:(UIWebView *)webView

{

NSString *json;

  NSString *str = [webViewstringByEvaluatingJavaScriptFromString:[NSStringstringWithFormat:@"getTokenMobileCallback(%@);",json]];

    NSLog(@"JS返回值:%@",str);

}


2js 调 iso ,ios 回调js


#import 
   
   
    
    
#import 
    
    
     
     

@protocol JSObjcDelegate 
     
     
      
      
- (void)getTokenMobile;
 
@end

@interface WebViewController : UIViewController 
      
      
       
       

@property (nonatomic, strong) JSContext *jsContext;
@property (strong, nonatomic)  UIWebView *webView;
 
@end


@implementation WebViewController


- (void)webViewDidFinishLoad:(UIWebView *)webView
{
    self.jsContext = [webView valueForKeyPath:@"documentView.webView.mainFrame.javaScriptContext"];
    self.jsContext[@"bridgeObj"] = self;
    self.jsContext.exceptionHandler = ^(JSContext *context, JSValue *exceptionValue) {
        context.exception = exceptionValue;
        NSLog(@"异常信息:%@", exceptionValue);
    };
}
 //js 调用的方法
- (void)getTokenMobile
{
    NSLog(@"call");
    // 之后在回调js的方法Callback把内容传出去
    JSValue *ocCallback = self.jsContext[@"ocCallback"];
    //传值给web端
    
    NSString *token;
    NSString *mobile;
    
    NSDictionary *dic = @{@"mobile":mobile,@"token":token};
    NSError *parseError = nil;
    NSData *jsonData = [NSJSONSerialization dataWithJSONObject:dic options:NSJSONWritingPrettyPrinted error:&parseError];
    NSString* str =  [[NSString alloc] initWithData:jsonData encoding:NSUTF8StringEncoding];
    //回调js方法
    [ocCallback callWithArguments:@[str]];
}

@end




       
       



       
       

JS与OC交互

<script> var ocCallback = function(str) { alert(str); } </script>

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值