混合开发的重要性不言而喻,一个移动端开发的了解前端开发是一个趋向,总之每个人都向往成为一个全栈工程师,废话不多说,直接上主题

一、交互(UIWebView)

1、OC调用JS

  (1)OC调用代码

  [self.webView stringByEvaluatingJavaScriptFromString:@"ocCallJSFunction({'name':'xiaoxiao'})"];

 (2)JS代码

  </script>
   function ocCallJSFunction(data) {
    var obj = eval(data);
    alert(obj.name);
   }
  <script>

2、JS调用OC

(1)OC代码

  - (void)webViewDidFinishLoad:(UIWebView *)webView {

  JSContext *context = [webView valueForKeyPath:@"documentView.webView.mainFrame.javaScriptContext"];

  context[@"jsCallOCFunction"] = ^() {

   NSLog(@"JS调用OC成功");

   NSArray *args = [JSContext currentArguments];

  for (JSValue *jsVal in args) {

  NSLog(@"%@", jsVal.toDictionary);

    }

    };

  }

 (2)JS调用代码

  </script>

  var message = {
    'method' : 'hello',
    'param1' : 'dada',
   };
  jsCallOCFunction(message);

  <script>

二、交互(WKWebView)

1、OC调用JS

  (1)OC调用代码

    [self.wkWebView evaluateJavaScript:@"ocCallJSFunction({'name':'xiaoxiao'})" completionHandler:^(id _Nullable obj, NSError * _Nullable error) {

     NSLog(@"evaluateJavaScript, obj = %@, error = %@", obj, error);

   }];

 (2)JS代码

  </script>
   function ocCallJSFunction(data) {
    var obj = eval(data);
    alert(obj.name);
   }
  <script>

2、JS调用OC

(1)OC代码

  // 初始化WKWebView

  WKWebViewConfiguration *config = [[WKWebViewConfiguration alloc] init];

  [config.userContentController addScriptMessageHandler:self name:@"jsCallOCFunction"];

WKWebView *wkWebView = [[WKWebView alloc] initWithFrame:CGRectZero configuration:config];

  

  #pragma mark - WKScriptMessageHandler

  - (void)userContentController:(WKUserContentController *)userContentController didReceiveScriptMessage:(WKScriptMessage *)message {

  NSLog(@"name = %@",message.name);

  NSLog(@"body = %@",message.body);

   NSLog(@"frameInfo = %@",message.frameInfo);

  }

 (2)JS调用代码

  </script>

  var message = {
    'method' : 'hello',
    'param1' : 'dada',
   };
  window.webkit.messageHandlers.jsCallOCFunction.postMessage(message);

  <script>

三、交互(WebViewJavascriptBridge)

功能总结:

OC调JS调用成功,JS可以回调数据到OC

JS调OC调用成功,OC可以回调数据到JS

1、OC调用JS

  (1)OC调用代码

  _bridge = [WebViewJavascriptBridge bridgeForWebView:wkWebView];

  id data = @{@"name" : @"xiaoxiao"};

  [_bridge callHandler:@"ocCallJSFunction" data:data responseCallback:^(id response) {

   NSLog(@"这里是OC调用JS成功后,JS回调的参数:%@", response);

  }];

 (2)JS代码

  </script>

  // 注册JS方法供OC调用
  bridge.registerHandler('ocCallJSFunction', function(data, responseCallback) {
    var obj = eval(data);
    alert(obj.userId);

    var responseData = { 'code':'200' }
    responseCallback(responseData)
  })

  <script>

2、JS调用OC

(1)OC代码

  [_bridge registerHandler:@"jsCallOCFunction" handler:^(id data, WVJBResponseCallback responseCallback) {

NSLog(@"JS传过来的参数: %@", data);

responseCallback(@"这是JS调用OC成功后,OC回调的参数");

}];

 (2)JS调用代码

  // JS调用OC注册的方法
  bridge.callHandler('jsCallOCFunction', {'name':'dada'}, function responseCallback(responseData) {

    alert(responseData);
  })

iOS JS与原生交互(全集)的更多相关文章

  1. iOS JS 和 OC交互 / JS 和 native 相互调用

    现在app 上越来越多需求是通过UIWebView 来展示html 或者 html5的内容, js 和 native OC代码交互 就非常常见了. js 调用 native  OC代码 第一种机制 ( ...

  2. Android 中 js 和 原生交互

    Android中的WebView 中加载的URL 默认是在手机浏览器中加载的,我们可以覆盖这种默认的动作,让网页在WebView中打开.通过设置WebView的WebViewClent 达到这个效果. ...

  3. iOS: JS和Native交互的两种方法

    背景: UIWebView: iOS 用来展示 web 端内容的控件. 1. 核心方法: - (NSString*)stringByEvaluatingJavaScriptFromString:(NS ...

  4. iOS开发--JS调用原生OC篇

    JS调用原生OC篇 方式一(反正我不用) 第一种方式是用JS发起一个假的URL请求,然后利用UIWebView的代理方法拦截这次请求,然后再做相应的处理. 我写了一个简单的HTML网页和一个btn点击 ...

  5. iOS下JS与原生OC互相调用(总结)

    这是去年总结的一篇文章,也一并先放到这个目录下好了. iOS开发免不了要与UIWebView打交道,然后就要涉及到JS与原生OC交互,今天总结一下JS与原生OC交互的两种方式. JS调用原生OC篇 方 ...

  6. iOS下JS与原生的交互一

    本篇主要讲的是UIWebView和JS的交互,在下一节会有wkWebView和JS交互的详解https://www.cnblogs.com/llhlj/p/9144110.html JS调用原生OC ...

  7. 转载 【iOS开发】网页JS与OC交互(JavaScriptCore) OC ----->JS

      目标 本文介绍利用苹果在iOS7时发布的JavaScriptCore.framework框架进行js与OC的交互.我们想要达到的目标是: OC调用网页上的js方法 网页js调用APP中的OC方法 ...

  8. iOS JS 交互之利用系统JSContext实现 JS调用OC方法以及Objective-C调用JavaScript方法

    ios js 交互分为两块: 1.oc调用js 这一块实现起来比较简单, 我的项目中加载的是本地的html,js,css,需要注意的是当你向工程中拖入这些文件时,选择拷贝到工程中,(拖入的文件夹是蓝色 ...

  9. iOS JS 交互之利用系统JSContext实现 JS调用oc方法

    ios js 交互分为两块: 1.oc调用js 这一块实现起来比较简单, 我的项目中加载的是本地的html,js,css,需要注意的是当你向工程中拖入这些文件时,选择如下操作,(拖入的文件夹是蓝色的, ...

随机推荐

  1. sublime for mac 注册码

    https://www.jianshu.com/p/04e1b65dd2c0https://fatesinger.com/100121

  2. Spring Boot(七):spring boot测试介绍

    首先maven要引入spring-boot-starter-test这个包. 先看一段代码 @RunWith(SpringRunner.class) @SpringBootTest(webEnviro ...

  3. atitit.企业管理----商业间谍策略的使用与防务

    atitit.企业管理----商业间谍策略的使用与防务 1. 间谍的历史 2 1.1. 公元前10世纪,<旧约全书>中的<士师记>里讲述了参孙的故事是最早的间谍故事. 2 1. ...

  4. 小马哥课堂-统计学-z分数

    Standard score(z-分数) The standard score is the signed number of standard deviations by which the val ...

  5. java之Thread Dump分析

    什么是Thread Dump Thread Dump是非常有用的诊断Java应用问题的工具.每一个Java虚拟机都有及时生成所有线程在某一点状态的thread-dump的能力,虽然各个 Java虚拟机 ...

  6. 写一个php小脚本辅助渗透测试

    因为一个注入要爬行一些数据,然后写的一个小脚本,能写脚本来辅助渗透,也算是里程碑.哈哈哈 <?php $num = 1; while ($num <= 39) { $web_url = & ...

  7. centos单机安装Hadoop2.6

    一,安装环境 硬件:虚拟机 操作系统:Centos 6.4 64位 IP:10.51.121.10 主机名:datanode-4 安装用户:root 二,安装JDK 安装JDK1.6或者以上版本.这里 ...

  8. shell变量/环境变量和set/env/export用法_转

    转自:shell环境变量以及set,env,export的区别 一.shell环境变量的分类以及set env export的区别: set:显示(设置)shell变量,包括的私有变量以及用户变量.不 ...

  9. RTT第一个工程

    第一个RTT工程 1. 配置工程 选择芯片STM32F103C8(其包含该芯片的Flash及SRAM介绍): Jlink  SW模式 output->Debug info/Browse info ...

  10. 微信小程序5 - 数据驱动界面

    微信小程序不可以使用js直接控制界面元素.而是通过改变 this.data中的属性,同步到界面 这个问题可以克服,带来的就是和H5不一样的编码方式.JS中更多的是改变数据的逻辑,而不是获取某个View ...