【iOS开发】UIWebView与JavaScript(JS) 回调交互

本文介绍了一个基于iOS的WebView与原生应用交互的实现方案。通过使用WebViewJavascriptBridge框架,文章详细展示了如何设置UIWebView来加载远程网页,并建立JavaScript与Objective-C之间的通信桥梁。文中还提供了具体的代码示例,包括如何注册处理程序以及从原生端调用Web端的方法。
依赖 WebViewJavascriptBridge 网上随便找,随便下
//
//  BaseWebRelationshipController.m
//  matchPlus
//
//  Created by mnn on 16/4/5.
//  Copyright © 2016年 mnn. All rights reserved.
//

#import "BaseWebRelationshipController.h"
#import "WebViewJavascriptBridge.h"

@interface BaseWebRelationshipController ()<UIWebViewDelegate , WebViewJavascriptBridgeBaseDelegate>{
    WebViewJavascriptBridge *_bridge;
}


@end

@implementation BaseWebRelationshipController

- (void)viewDidLoad {
    [super viewDidLoad];
    UIWebView *web = [[UIWebView alloc]initWithFrame:self.view.bounds];
    NSString *path = 连接;
    NSURL *url = [NSURL URLWithString:path];
    [web loadRequest:[NSURLRequest requestWithURL:url]];
    web.delegate = self;
    [self.view addSubview:web];
    
    if (_bridge) { return; }
    [WebViewJavascriptBridge enableLogging];
    _bridge = [WebViewJavascriptBridge bridgeForWebView:web];
    
    // JS 触发我的
    [_bridge registerHandler:@"webview_call_native" handler:^(id data, WVJBResponseCallback responseCallback) {
        NSLog(@"callback回来的: %@", data);
        // 这里是web端 callback 根据约定type 处理事件<pre name="code" class="objc">    }];
}



// 处理完事件后 callback web刷新数据
- (void)webView:(NSNotification *)text{
    // 你触发web的 客户端操作后callback web做响应处理<pre name="code" class="objc">    [_bridge callHandler:@"native_call_webview" data:@{@"tagname":@"updatewebview"}];
}


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值