`
吃饱了就饿
  • 浏览: 68992 次
  • 性别: Icon_minigender_2
  • 来自: 北京
社区版块
存档分类
最新评论

WebViewJavascriptBridge使用说明(IOS)

    博客分类:
  • IOS
阅读更多

 因为最近项目需要跨平台,在网上找到这个demo拿来用。

 首先简单说一下跨平台。

 由于现在很多产品都是有安卓版跟ios版,就意味着同一样东西要出两套,由两组人去完成,不仅增加了开发成本,也大大加剧了维护成本。聪明的coder想出了跨平台的思路,用html写页面,分别用webview(ios),(安卓)来加载,对某些html无法调用的硬件,通过双方的交互来实现方法的互调和传值。这个过程就是跨平台。

 下面来说一下WebViewJavascriptBridge在ios端怎么样使用。

 首先确保一份已经配好功能的html文件。(html还在学习阶段,暂时就不卖弄了。。。)

 1.初始化一个webview(viewdidload)

    UIWebView* webView = [[UIWebView alloc] initWithFrame:self.view.bounds];
    [self.view addSubview:webView];

 2.将此webview与WebViewJavascriptBridge关联(viewdidload)

 

 

    if (_bridge) { return; }

    [WebViewJavascriptBridge enableLogging];
    
    _bridge = [WebViewJavascriptBridge bridgeForWebView:webView webViewDelegate:self handler:^(id data, WVJBResponseCallback responseCallback) {
        NSLog(@"ObjC received message from JS: %@", data);
        
        responseCallback(@"Response for message from ObjC");
    }];

 ps:此时你的webview就与js搭上桥了。下面就是方法的互调和参数的互传。

 

 (1) js调oc方法(可以通过data给oc方法传值,使用responseCallback将值再返回给js)

 

   [_bridge registerHandler:@"testObjcCallback" handler:^(id data, WVJBResponseCallback responseCallback) {
        NSLog(@"testObjcCallback called: %@", data);
        responseCallback(@"Response from testObjcCallback");
    }];

  这里注意testObjcCallback这个方法的标示。html那边的命名要跟ios这边相同,才能调到这个方法。当然这个名字可以两边商量着自定义。简单明确即可。

 

  (2)oc调js方法(通过data可以传值,通过response可以接受js那边的返回值

   id data = @{ @"greetingFromObjC": @"Hi there, JS!" };
    [_bridge callHandler:@"testJavascriptHandler" data:data responseCallback:^(id response) {
        NSLog(@"testJavascriptHandler responded: %@", response);
    }];

 注意这里的testJavascriptHandler也是个方法标示。

 

 (3)oc给js传值(通过response接受返回值

    [_bridge send:@"A string sent from ObjC to JS" responseCallback:^(id response) {
        NSLog(@"sendMessage got response: %@", response);
    }];

  (4)oc给js传值(无返回值)

    [_bridge send:@"A string sent from ObjC after Webview has loaded."];

 暂时总结了这么些。下面有demo大家可以自己看看。有什么不懂的欢迎留言。

 

 

 

 

 

 

 

 

 

1
0
分享到:
评论

相关推荐

    iOS 使用WebViewJavascriptBridge与h5交互

    下面我们将详细讨论如何使用`WebViewJavascriptBridge`来实现iOS与H5的交互。 首先,`WebViewJavascriptBridge`的核心功能是建立一个桥梁,让Objective-C或Swift代码能够调用JavaScript函数,并且JavaScript也能...

    使用ncnn在ios+android上部署yolov5源码+详细说明.zip

    使用ncnn在ios+android上部署yolov5源码+详细说明.zip使用ncnn在ios+android上部署yolov5源码+详细说明.zip使用ncnn在ios+android上部署yolov5源码+详细说明.zip使用ncnn在ios+android上部署yolov5源码+详细说明.zip...

    ios软件设计说明书

    《iOS软件设计说明书》 在当今移动互联网时代,iOS平台因其稳定性和用户体验的良好口碑,成为了众多开发者和用户的首选。本说明书将深入探讨iOS软件的设计理念、流程和技术要点,旨在为开发者提供一份详尽的指导...

    IOS-使用ijkplayer简单demo

    这个"IOS-使用ijkplayer简单demo"是一个帮助开发者快速理解并集成ijkplayer到iOS项目的实例。下面我们将详细探讨ijkplayer的使用、核心概念以及如何通过提供的VideoDemo来学习ijkplayer的基本操作。 1. **...

    使用WebViewJavascriptBridge实现 OC 与 JS 交互(iOS源代码)

    学习如何使用WebViewJavascriptBridge,配有详细的使用教程,讲基本实现原理及如何在JS端、iOS端接入 WebViewJavascriptBridge是支持到iOS6之前的版本的,用于支持native的iOS与javascript交互。如果需要支持到iOS6...

    毕业设计使用ncnn在ios+android上部署yolov5源码+详细说明.zip

    高分毕业设计 毕业设计源码 使用ncnn在ios+android上部署yolov5源码+详细说明.zip 高分毕业设计 毕业设计源码 使用ncnn在ios+android上部署yolov5源码+详细说明.zip 高分毕业设计 毕业设计源码 使用ncnn在ios+...

    ios helper用于苹果ios系统的实用工具

    在iOS设备的使用过程中,用户常常会遇到各种问题,例如系统更新、数据管理、应用安装等。而"iOS Helper"正是为解决这些问题而设计的一款强大实用工具,专为苹果iOS系统提供全方位的支持和服务。 首先,iOS Helper的...

    WebViewJavascriptBridge详细使用

    本篇讲讲WebViewJavascriptBridge的基本原理及详细讲讲如何去使用,包括iOS端的使用和JS端的使用。 经过多番百度、Google,发现WebViewJavascriptBridge的资源讲解不是翻译官方文档就是直接说官方提供的demo。但是...

    Android代码-WebViewJavaScriptBridge

    和IOS marcuswestin/WebViewJavascriptBridge 一样的使用方法,可共用一套JS代码。 同时也在此之上做了加强,参考了Cordova源码的模块管理,方便把各种不同的原生功能封装成独立的模块并统一管理。具体请看下面的 ...

    WebViewJavascriptBridge

    WebViewJavascriptBridge是一款在移动应用开发中广泛使用的框架,它允许Android和iOS的原生代码与JavaScript之间进行双向通信。在混合开发模式下,这个工具显得尤为重要,因为它可以帮助开发者轻松地在Web视图...

    WebViewJavascriptBridge 简化实现(简单易懂)

    WebViewJavascriptBridge 是一个在iOS和Android平台上广泛使用的框架,它为原生应用和JavaScript之间提供了一种方便的通信桥梁。这个框架使得JavaScript可以调用原生应用的功能,同时原生应用也能向JavaScript发送...

    WebViewJavascriptBridge 开源代码含有分析

    在iOS开发中,WebViewJavascriptBridge是一个非常重要的工具,它允许JavaScript和原生iOS代码之间进行无缝的通信。这个开源项目为开发者提供了一种优雅的方式来实现JS与iOS Native Code的交互,极大地增强了Web视图...

    Android代码-WebViewJavascriptBridge

    重要通知 由于DSBridge(笔者开发的一个更强大的跨平台JavaScript Bridge... and It is a mirror of marcuswestin/WebViewJavascriptBridge (object-c) and Lision/WKWebViewJavascriptBridge(swift) which supports IOS

    ios-WKWebView.zip

    本项目“ios-WKWebView.zip”主要关注如何利用WKWebView以及WebviewJavaScriptBridge实现原生iOS应用与JavaScript的交互。 WKWebView的引入解决了UIWebView在渲染现代网页时的效率问题,它基于WebKit引擎,提供了更...

    location驱动ios12.4 ios12.3 ios12.2 ios12.1 ios12.0 ios11.0 ios11.4

    标题和描述中提到的“location驱动ios12.4 ios12.3 ios12.2 ios12.1 ios12.0 ios11.0 ios11.4”意味着这是一个关于不同iOS版本中位置驱动的讨论,涵盖了从iOS 11.0到iOS 12.4的多个版本。 1. iOS中的定位服务:iOS...

    苹果说明书没说明的那些iOS使用技巧.docx

    "苹果说明书没说明的那些iOS使用技巧" iOS 操作系统是当前全球最受欢迎的移动操作系统之一,凭借其闭源性质、简洁直观的界面设计、隐私保护得力、丰富的应用程序商店和便捷的设备管理等优势和特性,iOS 操作系统...

    拍照并上传照片和说明的 iOS 客户端

    在开发“拍照并上传照片和说明的 iOS 客户端”时,我们需要关注以下几个关键知识点: 1. **iOS 应用程序开发环境**:首先,我们需要使用 Xcode,这是Apple官方提供的集成开发环境(IDE),用于编写Objective-C或...

    思科路由器升级IOS

    升级前建议备份现有IOS,可以使用`dir flash:`命令查看当前IOS文件,然后执行`copy flash tftp`命令备份到TFTP服务器。 3. **执行升级**:使用`copy tftp flash`命令从TFTP服务器下载新IOS到路由器的闪存中。输入...

Global site tag (gtag.js) - Google Analytics