首页 > PHP资讯 > HTML5培训技术 > 详解使用JavaScriptCore实现OC和JS交互的示例代码

详解使用JavaScriptCore实现OC和JS交互的示例代码

HTML5培训技术
#wiki/48.html" target="_blank">JavaScriptCore是webkit的一个重要组成部分,主要是对JS进行解析和提供执行环境。下面这篇文章主要给大家介绍了使用JavaScriptCore实现OC和JS交互的相关资料,文中介绍的非常详细,需要的朋友可以参考学习,下面来一起看看吧。

JavascriptCore

JavascriptCore是webkit的一个重要组成部分,主要是对JS进行解析和提供执行环境。iOS7后苹果在iPhone平台推出,极大的方便了我们对js的操作。

首先创建webView,读取本地的html文件

 NSURL* htmlURL = [[NSBundle mainBundle] URLForResource: @"demo" withExtension: @"html"];[_webView loadRequest: [NSURLRequest requestWithURL: htmlURL]];

在demo中,我们要实现4种情况

  1. JS调用OC

  2. JS调用OC并传递参数

  3. OC调用JS

  4. OC调用JS并传递参数

html文件中代码如下

  <script type="text/javascript"> function showAlert(){  alert('OC call JS with no argument'); } function showAlertWithString(string){  alert(string); } function callOCWithArgument() {  jsCallOCWithArgument('参数1 ','参数2 ','参数3'); } 《script》 



JS调用OC

在webView的代理方法webViewDidFinishLoad中

-(void)webViewDidFinishLoad:(UIWebView *)webView{ _context = [webView valueForKeyPath:@"documentView.webView.mainFrame.javascriptContext"]; weak typeof(self) weakSelf = self; _context.exceptionHandler = ^(JSContext *context, JSValue *exception) {  weakSelf.context.exception = exception; }; //js调用OC _context[@"callOC"] = ^() {  NSArray *args = [JSContext currentArguments];  for (JSValue *jsVal in args) {   NSLog(@"%@", jsVal.toString);  }  dispatch_async(dispatch_get_main_queue(), ^{   UIAlertController *alertView = [UIAlertController alertControllerWithTitle:@"arguments"    message:@"JS Call OC With No Argument" preferredStyle:UIAlertControllerStyleAlert];   UIAlertAction * action = [UIAlertAction actionWithTitle:@"Done" style:UIAlertActionStyleDefault handler:^(UIAlertAction * _Nonnull action) {   }];   [alertView addAction:action];   [weakSelf presentViewController:alertView animated:YES completion:nil];  }); }; _context[@"jsCallOCWithArgument"] = ^() {  NSArray *args = [JSContext currentArguments];  NSMutableString * stirng = [NSMutableString string];  for (JSValue * value in args) {   [stirng appendString:value.toString];  }  dispatch_async(dispatch_get_main_queue(), ^{   UIAlertController *alertView = [UIAlertController alertControllerWithTitle:@"arguments" message:stirng preferredStyle:UIAlertControllerStyleAlert];   UIAlertAction * action = [UIAlertAction actionWithTitle:@"Done" style:UIAlertActionStyleDefault handler:^(UIAlertAction * _Nonnull action) {   }];   [alertView addAction:action];   [weakSelf presentViewController:alertView animated:YES completion:nil];  }); }; }

我们定义一个block,然后保存到context里面,其实就是转换成了JS中命名为callOC的function。然后我们直接执行这个function,调用的就是我们的block里面的内容了。

传过来的参数可以通过[JSContext currentArguments]这个array接受,里面是JSValue对象。

OC调用JS

初始化两个Button,在点击事件中实现如下方法

- (IBAction)callJS:(id)sender { [_context evaluatescript:@"showAlert()"];}- (IBAction)callJSWithArguments:(id)sender { [_context evaluatescript:@"showAlertWithString('OC call JS with arguments')"];// [_context[@"showAlertWithString"] callWithArguments:@[@"OC call JS with arguments"]];}

即可实现OC调用JS。

总结

以上就是详解使用JavaScriptCore实现OC和JS交互的示例代码的详细内容,更多请关注 第一PHP社区 其它相关文章!

HTML5培训技术

本文由欣才IT学院整理发布,未经许可,禁止转载。
支持21不支持0