2018-02-07

作者: 狂妄的雄狮 | 来源:发表于2018-02-27 14:22 被阅读0次

OC与H5交互

交互的四种方式

  • 有很多的app直接使用在webview的代理中通过拦截的方式与native进行交互,通常是通过拦截url scheme判断是否是我们需要拦截处理的url及其所对应的要处理的功能是什么。任意版本都支持。
  • iOS7之后出了JavaScriptCore.framework用于与JS交互,但是不支持iOS6,对于还需要支持iOS6的app,就不能考虑这个了。若需要了解,看最后的推荐阅读。
  • WebViewJavascriptBridge开源库使用,本质上,它也是通过webview的代理拦截scheme,然后注入相应的JS。
  • react-native,这个没玩过(与前三种不同)。

1.UIWebView 和 js 交互

 ViewController.m:
 #import "WebViewController.h"
 #import "WebViewModel.h"
 @interface WebViewController ()
 @property (nonatomic, strong) UIWebView *webView;
 @property (nonatomic, strong) JSContext *jsContext;
 @property (nonatomic, strong) WebViewModel *model;
 @end
 @implementation WebViewController
 - (void)viewDidLoad {
 [super viewDidLoad];
 [self.view addSubview:self.webView]
 }
     // 通过懒加载创建webView 
-(UIWebView *)webView {
if (_webView == nil) {
 _webView = [[UIWebView alloc] initWithFrame:self.view.bounds];
 NSURL *url = [[NSBundle mainBundle]         URLForResource:@"callEach" withExtension:@"html"];
 [_webView loadRequest:[NSURLRequest requestWithURL:url]];
 //忽略web页面与_WebView组件的大小关系如果设置为YES可以执行缩放,但是web页面加载出来的时候,就会缩小到UIWebView组件的大小
 _webView.scalesPageToFit = NO;
 _webView.delegate = self;
 }
 return _webView;
 }

pragma mark - UIWebViewDelegate

 -(void)webViewDidFinishLoad:(UIWebView *)webView {
self.jsContext = [webView valueForKeyPath:@"documentView.webView.mainFrame.javaScriptContext"];
WebViewModel *model  = [[WebViewModel alloc] init];
self.jsContext[@"CallEachModel"] = model;
model.jsContext = self.jsContext;
model.webView = self.webView;
model.currentVC = self;
self.model = model;
self.jsContext.exceptionHandler = ^(JSContext *context, JSValue *exceptionValue) {
    context.exception = exceptionValue;
    NSLog(@"异常信息:%@", exceptionValue);
};
}
- (void)webViewDidStartLoad:(UIWebView *)webView {

}
   @end

2. model.h:

#import
@protocol WebViewJSExport<JSExport>
/** 遵守了 协议后 这些方法就暴露给 js 调用 **/
/** jsCallOC **/
- (void)jsCallOC;
- (void)jsCallOCWithString:(NSString *)string;
//js调用时候取函数名就好了 不要冒号 jsCallOCWithTitleMessage
- (void)jsCallOCWithTitle:(NSString *)title message:(NSString *)msg;
- (void)jsCallOCWithDictionary:(NSDictionary *)dictionary;
- (void)jsCallOCWithArray:(NSArray *)array;
/** ocCallJS **/
- (void)ocCallJS;
- (void)ocCallJSWithString:(NSString *)string;
- (void)ocCallJSWithTitle:(NSString *)title message:(NSString *)message; 
- (void)ocCallJSWithDictionary:(NSDictionary *)dictionary;
- (void)ocCallJSWithArray:(NSArray *)array;
/** callEach **/
- (void)jsCallOCAndOCCallJSWithParams:(NSDictionary *)params;
- (void)ocCallJSAndJSCallOCWithParams:(NSDictionary *)params;
@end
@class BaseViewController;
@interface WebViewModel : NSObject <WebViewJSExport>
@property (nonatomic, weak) JSContext *jsContext;
@property (nonatomic, weak) UIWebView *webView;
@property (nonatomic, weak) BaseViewController *currentVC;   
@end

3.model.m

#import "WebViewModel.h"
#import "BaseViewController.h"
@implementation WebViewModel
#pragma mark - jsCallOC
- (void)jsCallOC {
dispatch_async(dispatch_get_main_queue(), ^{
UIAlertView *alert = [[UIAlertView alloc] initWithTitle:nil
                                                    message:@"jsCallOC"
                                                   delegate:nil
                                          cancelButtonTitle:@"I konw"
 ]
                                          otherButtonTitles:nil, nil];
    [alert show];

});
}
- (void)jsCallOCWithString:(NSString *)string {
dispatch_async(dispatch_get_main_queue(), ^{
UIAlertView *alert = [[UIAlertView alloc] initWithTitle:string
                                                    message:nil
                                                   delegate:nil
                                          cancelButtonTitle:@"I konw"
                                          otherButtonTitles:nil, nil];
    [alert show];
});
}
- (void)jsCallOCWithTitle:(NSString *)title message:(NSString *)msg {
dispatch_async(dispatch_get_main_queue(), ^{
UIAlertView *alert = [[UIAlertView alloc] initWithTitle:title
                                                    message:msg
                                                   delegate:nil
                                          cancelButtonTitle:@"I konw"
                                          otherButtonTitles:nil, nil];
    [alert show];
});
}
- (void)jsCallOCWithDictionary:(NSDictionary *)dictionary {
dispatch_async(dispatch_get_main_queue(), ^{
UIAlertView *alert = [[UIAlertView alloc] initWithTitle:dictionary[@"title"]
                                                    message:dictionary[@"message"]
                                                   delegate:nil
                                          cancelButtonTitle:@"I konw"
                                          otherButtonTitles:nil, nil];
    [alert show];
});
}
- (void)jsCallOCWithArray:(NSArray *)array {
dispatch_async(dispatch_get_main_queue(), ^{
UIAlertView *alert = [[UIAlertView alloc] initWithTitle:array[0]
                                                    message:array[1]
                                                   delegate:nil
                                          cancelButtonTitle:@"I konw"
                                          otherButtonTitles:nil, nil];
    [alert show];
});
}

//OC调用JS代理

- (void)ocCallJS {
JSValue *jsFunc = self.jsContext[@"func1"];
[jsFunc callWithArguments:nil];
}
- (void)ocCallJSWithString:(NSString *)string {
NSInteger arc = arc4random()%1000;
JSValue *jsFunc = self.jsContext[@"func2"];
[jsFunc callWithArguments:@[@{@"title": @"change--> myoctitle", @"message": @(arc)}]];
}
  - (void)ocCallJSWithTitle:(NSString *)title message:(NSString * )message {
}
- (void)ocCallJSWithDictionary:(NSDictionary *)dictionary {

}

- (void)ocCallJSWithArray:(NSArray *)array {



 }

pragma mark - callEach

- (void)jsCallOCAndOCCallJSWithParams:(NSDictionary *)params {
[self.currentVC createTopView];
self.currentVC.field.text = params[@"title"];
[self.currentVC setBlock:^(NSString *string){
if (string != nil && string.length > 0) {
JSValue *jsFunc = self.jsContext[@"func2"];
[jsFunc callWithArguments:@[@{@"title":@"js 调出来topView 输入填充到html:" , @"message": string}]];
    }
}];
}
- (void)ocCallJSAndJSCallOCWithParams:(NSDictionary *)params {
JSValue *jsFunc = self.jsContext[@"func3"];
[jsFunc callWithArguments:@[@{@"title": @"myoctitle", @"message": @"myocmessage"}]];
}
@end

此文章有摘抄,如若侵权请通知我。

相关文章

  • 2018-02-07-00714班作业汇总

    1、2018-02-07演讲战队作业雨汇总 2、2018-02-07投资组作业雨汇总 3、2018-02-07英语...

  • es6-Symbol

    title: es6-Symboldate: 2018-02-07 22:40:00tags: es6 前言 突然...

  • 每日确定

    New logo 创作你的创作 免费下载 2018-02-07 180 孙仕霞 简书作者 2018.02.06 0...

  • 险峰

    2018-02-07 ——岁月如歌诗词选(第二集.37) 覌微信《毕福剑之后,赵...

  • 145|怎样战胜“女孩没有男孩聪明”的偏见?

    145|怎样战胜“女孩没有男孩聪明”的偏见? Dr. 魏 2018-02-07 145|怎样战胜“女孩没有男孩聪明...

  • 寒假见闻

    寒假见闻 2018-02-07 作者:柠檬的味道像雨天 977685人读过 寒假里,发生过许多愉快的事...

  • 2018-02-07

    禾隆李亮 2018-02-07 21:23 · 字数 270 · 阅读 3 · 日记本 【日精进打卡第34天】 宁...

  • 一朵敢于争先的小花

    古树望月 2018-02-07 03:45 · 字数 471 · 阅读 1 · 日记本 春天和夏天不同,春天里大...

  • 基金定投

    关于基金定投 木沁原 2018-02-07 14:53 · 字数 392 · 阅读 1 · 日记本 基金定投:定期...

  • 一篇气死99个老师的中学生作文

    一篇气死99个老师的中学生作文 2018-02-07 作者:柠檬的味道像雨天 85567人读过 ...

网友评论

    本文标题:2018-02-07

    本文链接:https://www.haomeiwen.com/subject/mnjazxtx.html