热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

JS与OC交互

UIWebView拦截URL原理:js通过加载url方式被webView拦截,这时候看如果是自己定义的scheme请求就不让webView继续加载请求,否则就继续加载请求。webV



UIWebView拦截URL



  1. 原理:



    1. js通过加载url方式被webView拦截,这时候看如果是自己定义的scheme请求就不让webView继续加载请求,否则就继续加载请求。

    2. webView看加载的请求的host是哪种host进行分别处理。

    3. 处理oc代码。

    4. 之后调用stringByEvaluatingJavascriptFromString调用js代码。



  2. 注意:



    1. js调用oc属于异步方式

    2. oc调用js属于同步方式,且必须在主线程加载,如果js代码比较耗时那么可能会卡顿主线程



  3. 代码地址




UIWebview利用jsc库



  1. 原理:



    1. html调用方法:

      function locationClick() {

      getLocation(‘A’,‘B’,‘C’);

      }

    2. oc中delegate回调:

    - (void)webViewDidFinishLoad:(UIWebView *)webView{
    JSContext *cOntext= [self valueForKeyPath:@"documentView.webView.mainFrame.JavascriptContext"];
    }


    1. 通过分析context[@“getLocation”]来判断方法名。

    2. 通过NSArray *arrArgs = [JSContext currentArguments];获取参数



  2. 注意:



    1. js执行时候会进入context的回调,该回调block是在子线程中的。如果更细ui要在主线程。



  3. 代码地址




WKWebView拦截URL



  1. 原理:



    1. js通过加载url方式被webView拦截,这时候看如果是自己定义的scheme请求就不让webView继续加载请求,否则就继续加载请求。

    2. webView看加载的请求的host是哪种host进行分别处理。

    3. 处理oc代码。

    4. 之后调用evaluateJavascript调用js代码。



  2. 注意:



    1. js调用oc属于异步方式

    2. oc调用js属于同步方式,且必须在主线程加载,如果js代码比较耗时那么可能会卡顿主线程

    3. WKWebView有个处理js弹窗的代理方法,这个方法必须要实现,如果不实现js的弹窗将会无效。



  3. WKWebView和UIWebView的比较



    1. wk更节省内存

    2. wk加载速度刚快

    3. wk解决了内存泄露问题

    4. wk刚好适配了ios8+



  4. 代码地址




WKWebView messageHandle方式



  1. 原理:

    1. js通过调用方法window.webkit.messageHandlers.getLocation.postMessage({A:‘a’,B:‘b’});其中getLocation为name,{A:‘a’,B:‘b’}相当于参数

    2. oc通过 [self.webView.configuration.userContentController addScriptMessageHandler:self name:obj];相当于注册监听

    3. oc会进入回调userContentController:(WKUserContentController *)userContentController didReceiveScriptMessage:(WKScriptMessage *)message。

    4. 通过分析message.name来判断是js调用的那个方法,通过分析message.body来获取参数。



代码地址


可以利用三方框架实现交互



  1. WebViewJavascriptBridge支持UIWebView,WKWebView

  2. 利用这个框架可以实现oc与js互调


可以利用前端框架



  1. RN可以实现

  2. Cordova可以实现


webView实现全包裹



  1. ios要想做到内容全包裹,必须借助js,不像android…

  2. js获取内容高度方法为:

CGFloat height = [[webView stringByEvaluatingJavascriptFromString:@"document.body.scrollHeight"] floatValue];


推荐阅读
  • 本文探讨了在UIScrollView上嵌入Webview时遇到的一个常见问题:点击图片放大并返回后,Webview无法立即滑动。我们将分析问题原因,并提供有效的解决方案。 ... [详细]
  • 本文将介绍如何编写一些有趣的VBScript脚本,这些脚本可以在朋友之间进行无害的恶作剧。通过简单的代码示例,帮助您了解VBScript的基本语法和功能。 ... [详细]
  • 本文介绍了如何使用JQuery实现省市二级联动和表单验证。首先,通过change事件监听用户选择的省份,并动态加载对应的城市列表。其次,详细讲解了使用Validation插件进行表单验证的方法,包括内置规则、自定义规则及实时验证功能。 ... [详细]
  • 本文详细介绍如何使用Python进行配置文件的读写操作,涵盖常见的配置文件格式(如INI、JSON、TOML和YAML),并提供具体的代码示例。 ... [详细]
  • 本文介绍了如何利用JavaScript或jQuery来判断网页中的文本框是否处于焦点状态,以及如何检测鼠标是否悬停在指定的HTML元素上。 ... [详细]
  • 导航栏样式练习:项目实例解析
    本文详细介绍了如何创建一个具有动态效果的导航栏,包括HTML、CSS和JavaScript代码的实现,并附有详细的说明和效果图。 ... [详细]
  • 前言--页数多了以后需要指定到某一页(只做了功能,样式没有细调)html ... [详细]
  • 本文介绍了在Windows环境下使用pydoc工具的方法,并详细解释了如何通过命令行和浏览器查看Python内置函数的文档。此外,还提供了关于raw_input和open函数的具体用法和功能说明。 ... [详细]
  • 在使用 MUI 框架进行应用开发时,开发者常常会遇到 mui.init() 和 mui.plusReady() 这两个方法。本文将详细解释它们的区别及其在不同开发环境下的应用。 ... [详细]
  • 本文讨论了如何根据特定条件动态显示或隐藏文件上传控件中的默认文本(如“未选择文件”)。通过结合CSS和JavaScript,可以实现更灵活的用户界面。 ... [详细]
  • 本文详细介绍了中央电视台电影频道的节目预告,并通过专业工具分析了其加载方式,确保用户能够获取最准确的电视节目信息。 ... [详细]
  • 在进行微信小程序开发过程中,遇到了需要实现类似微信朋友圈那样的长文本折叠功能的需求。本文将详细探讨其实现方法及注意事项。 ... [详细]
  • 如何在UIWebView中加载本地图片
    本文详细介绍了如何在UIWebView中加载本地图片的方法,这对于需要在应用内展示静态页面和富文本内容的场景非常有用。 ... [详细]
  • 本文详细介绍了如何使用 Yii2 的 GridView 组件在列表页面实现数据的直接编辑功能。通过具体的代码示例和步骤,帮助开发者快速掌握这一实用技巧。 ... [详细]
  • 基于KVM的SRIOV直通配置及性能测试
    SRIOV介绍、VF直通配置,以及包转发率性能测试小慢哥的原创文章,欢迎转载目录?1.SRIOV介绍?2.环境说明?3.开启SRIOV?4.生成VF?5.VF ... [详细]
author-avatar
坑爹的马_782
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有