热门标签 | 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];


推荐阅读
  • 本文详细探讨了JavaScript中的作用域链和闭包机制,解释了它们的工作原理及其在实际编程中的应用。通过具体的代码示例,帮助读者更好地理解和掌握这些概念。 ... [详细]
  • iOS 小组件开发指南
    本文详细介绍了iOS小部件(Widget)的开发流程,从环境搭建、证书配置到业务逻辑实现,提供了一系列实用的技术指导与代码示例。 ... [详细]
  • publicclassBindActionextendsActionSupport{privateStringproString;privateStringcitString; ... [详细]
  • 本文介绍了如何使用JavaScript的Fetch API与Express服务器进行交互,涵盖了GET、POST、PUT和DELETE请求的实现,并展示了如何处理JSON响应。 ... [详细]
  • 本文详细介绍如何使用 HTML5 和 JavaScript 实现一个交互式的画板功能。通过具体代码示例,帮助读者理解 Canvas API 的基本用法及其在绘图应用中的实际应用。 ... [详细]
  • 如何在UIWebView中加载本地图片
    本文详细介绍了如何在UIWebView中加载本地图片的方法,这对于需要在应用内展示静态页面和富文本内容的场景非常有用。 ... [详细]
  • 本文介绍了JSP的基本概念、常用标签及其功能,并通过示例详细说明了如何在JSP页面中使用Java代码。 ... [详细]
  • 基于JQuery实现的评分插件
    本文介绍了一个使用JQuery创建的交互式评分控件。当用户将鼠标悬停在星星上时,左侧的星星会变为实心,右侧保持空心,并显示对应的评分等级;移开鼠标后,所有星星恢复为空心状态。 ... [详细]
  • 在项目部署后,Node.js 进程可能会遇到不可预见的错误并崩溃。为了及时通知开发人员进行问题排查,我们可以利用 nodemailer 插件来发送邮件提醒。本文将详细介绍如何配置和使用 nodemailer 实现这一功能。 ... [详细]
  • Coursera ML 机器学习
    2019独角兽企业重金招聘Python工程师标准线性回归算法计算过程CostFunction梯度下降算法多变量回归![选择特征](https:static.oschina.n ... [详细]
  • 深入理解Vue.js:从入门到精通
    本文详细介绍了Vue.js的基础知识、安装方法、核心概念及实战案例,帮助开发者全面掌握这一流行的前端框架。 ... [详细]
  • Redux入门指南
    本文介绍Redux的基本概念和工作原理,帮助初学者理解如何使用Redux管理应用程序的状态。Redux是一个用于JavaScript应用的状态管理库,特别适用于React项目。 ... [详细]
  • 本文详细探讨了HTML表单中GET和POST请求的区别,包括它们的工作原理、数据传输方式、安全性及适用场景。同时,通过实例展示了如何在Servlet中处理这两种请求。 ... [详细]
  • 反向投影技术主要用于在大型输入图像中定位特定的小型模板图像。通过直方图对比,它能够识别出最匹配的区域或点,从而确定模板图像在输入图像中的位置。 ... [详细]
  • 随着毕业设计的结束,我终于有时间更新我的博客了。这次,我将分享如何在自己的服务器上搭建 Bitwarden,一个广受好评的开源密码管理工具。 ... [详细]
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社区 版权所有