iOS 与 js交互的其一方法 WebViewJavascriptBridge的使用

#import <WebViewJavascriptBridge.h>

///

@interface ZWBridgeViewController ()<WKNavigationDelegate, WKUIDelegate, UIGestureRecognizerDelegate>

@property (nonatomicstrong) ZWCommonNavBar *navBar;

@property (nonatomicstrong) WKWebView *webView;

@property (nonatomicstrong) WebViewJavascriptBridge *bridge;

@property (nonatomiccopy) NSString *urlStr;

@property (nonatomiccopy) NSString *webTitle;

@end

@implementation ZWBridgeViewController

- (instancetype)initWithParams:(NSDictionary *)params {

self = [super init];

if (self) {

}

return self;

}

- (void)viewDidAppear:(BOOL)animated

{

[super viewDidAppear:animated];

if ([self.navigationController respondsToSelector:@selector(interactivePopGestureRecognizer)]) {

self.navigationController.interactivePopGestureRecognizer.delegate = self;

}

}

- (void)viewWillDisappear:(BOOL)animated

{

[super viewWillDisappear:animated];

[SVProgressHUD dismiss];

if ([self.navigationController respondsToSelector:@selector(interactivePopGestureRecognizer)]) {

self.navigationController.interactivePopGestureRecognizer.delegate = nil;

}

}

- (BOOL)gestureRecognizerShouldBegin:(UIGestureRecognizer *)gestureRecognizer

{

return NO;

}

- (void)viewDidLoad {

[super viewDidLoad];

[SVProgressHUD show];

NSLog(@"%@",self.urlStr);

[self configNavBar];

[self configWebView];

[self configBridge];

[self configBridgeRegister];

[self configBridgeCallHander];

}

- (void)configNavBar {

self.titlle = ""

}

- (void)configWebView {

NSURL *url = [NSURL URLWithString:self.urlStr];

NSURLRequest *request = [NSURLRequest requestWithURL:url];

[self.webView loadRequest:request];

}

- (void)configBridge {

// 开启日志

[WebViewJavascriptBridge enableLogging];

self.bridge = [WebViewJavascriptBridge bridgeForWebView:self.webView];

[self.bridge setWebViewDelegate:self];

}

#pragma mark JS Call OC

- (void)configBridgeRegister {

kWeakSelf(self);

// 商品详情

[self.bridge registerHandler:@"func" handler:^(id data, WVJBResponseCallback responseCallback) {

NSDictionary *params = data;

NSDictionary *dic = @{

@"goodsId" : @([params[@"productId"] integerValue])

};

UIViewController *vc =

[weakself.navigationController pushViewController:vc animated:YES];

}];

[self.bridge registerHandler:@"nativeHomePage" handler:^(id data, WVJBResponseCallback responseCallback) {

[weakself zw_toHomeRootViewController];

}];

[self.bridge registerHandler:@"nativeGoback" handler:^(id data, WVJBResponseCallback responseCallback) {

[weakself.navigationController popviewcontroller]

}];

[self.bridge registerHandler:@"nativeOrderList" handler:^(id data, WVJBResponseCallback responseCallback) {

NSDictionary *params = @{

@"index" : @(0)

};

UIViewController *vc = [[CTMediator sharedInstance] ymd_mediator_MyOrderViewControllerWithParams:params];

[weakself.navigationController pushViewController:vc animated:YES];

BOOL closePage = [data[@"closePage"] integerValue];

if (closePage) {

NSMutableArray *mArray = [NSMutableArray arrayWithArray: weakself.navigationController.viewControllers];

[mArray removeObjectAtIndex: weakself.navigationController.viewControllers.count - 2];

weakself.navigationController.viewControllers = [NSArray arrayWithArray: mArray];

}

}];

[self.bridge registerHandler:@"nativeOrderListDetail" handler:^(id data, WVJBResponseCallback responseCallback) {

NSDictionary *resultData = data[@"resultData"];

NSDictionary *dic = @{

@"orderId" : @([resultData[@"orderId"] integerValue])

};

UIViewController *vc = [[CTMediator sharedInstance] ymd_mediator_MyOrderDetailViewControllerWithParams:dic];

[self.navigationController pushViewController:vc animated:YES];

BOOL closePage = [data[@"closePage"] integerValue];

if (closePage) {

NSMutableArray *mArray = [NSMutableArray arrayWithArray: weakself.navigationController.viewControllers];

[mArray removeObjectAtIndex: weakself.navigationController.viewControllers.count - 2];

weakself.navigationController.viewControllers = [NSArray arrayWithArray: mArray];

}

}];

[self.bridge registerHandler:@"nativeShare" handler:^(id data, WVJBResponseCallback responseCallback) {

NSDictionary *resultData = data[@"resultData"];

ZWFreeOrderShareVC *vc = [[ZWFreeOrderShareVC alloc] init];

vc.shareModel = shareModel;

[self.navigationcontroller push:vc animate:ture]

}];

[self.bridge registerHandler:@"nativeDominosDetail" handler:^(id data, WVJBResponseCallback responseCallback) {

NSDictionary *resultData = data[@"resultData"];

//        NSDictionary *relayParams = @{

//                                      @"dominosId" : @([resultData[@"dominosId"] integerValue]),

//                                      @"dominosOrderId" : @([resultData[@"dominosOrderId"] integerValue]),

//                                      @"type" : @(1)

//                                      };

NSDictionary *userInfo = @{

@"dominosOrderId" : @([resultData[@"dominosOrderId"] integerValue]),

};

[[NSNotificationCenter defaultCenter] postNotificationName:kZWFreeOderSuccessNotification object:nil userInfo:userInfo];

NSMutableArray *mArray = [NSMutableArray arrayWithArray: self.navigationController.viewControllers];

[mArray removeObjectAtIndex: self.navigationController.viewControllers.count - 1];

self.navigationController.viewControllers = [NSArray arrayWithArray: mArray];

   //[self.navigationcontroller push:vc animate:ture]

}];

}

#pragma mark OC Call JS

- (void)configBridgeCallHander {

[self.bridge callHandler:@"ocCallJs" data:@{@"name": @"James call"} responseCallback:^(id responseData) {

}];

}

#pragma mark WKNavigationDelegate

- (void)webView:(WKWebView *)webView didFinishNavigation:(WKNavigation *)navigation {

[webView evaluateJavaScript:@"document.documentElement.style.webkitUserSelect=‘none‘;" completionHandler:nil];

[webView evaluateJavaScript:@"document.documentElement.style.webkitTouchCallout=‘none‘;" completionHandler:nil];

[SVProgressHUD dismiss];

}

#pragma mark KVO

-(void)observeValueForKeyPath:(NSString *)keyPath ofObject:(id)object change:(NSDictionary *)change context:(void *)context{

if ([keyPath isEqualToString:@"title"]) {

if (object == self.webView) {

self.navBar.title = self.webView.title;

else {

[super observeValueForKeyPath:keyPath ofObject:object change:change context:context];

}

else {

[super observeValueForKeyPath:keyPath ofObject:object change:change context:context];

}

}

#pragma mark Lazy

- (WKWebView *)webView {

if (!_webView) {

_webView = [[WKWebView alloc] init];

_webView.navigationDelegate = self;

_webView.UIDelegate = self;

[_webView addObserver:self forKeyPath:@"title" options:NSKeyValueObservingOptionNew context:NULL];

[self.view addSubview:_webView];

[_webView mas_makeConstraints:^(MASConstraintMaker *make) {

make.edges.mas_equalTo(UIEdgeInsetsMake(k_Height_NavBar, 0, 0, 0));

}];

}

return _webView;

}

原文地址:https://www.cnblogs.com/sundaysgarden/p/11600646.html

时间: 2024-11-13 08:49:25

iOS 与 js交互的其一方法 WebViewJavascriptBridge的使用的相关文章

IOS Webview JS交互之事件拦截获取

最近项目中用到了webvVew,webView加载的网页中有两个按钮,要在app里面响应这两个按钮的点击事件,并接受JS传过来的参数. ios7 的时候,出来了一个新的类库叫JavaScriptCore.framework - (void)setupJsContent { //获取当前JS环境 _content = [_webView valueForKeyPath:@"documentView.webView.mainFrame.javaScriptContext"]; // 打印异

iOS与JS交互实战篇(ObjC版)

前言 ObjectiveC与Js交互是常见的需求,可对于新手或者所谓的高手而言,其实并不是那么简单明了.这里只介绍iOS7.0后出来的JavaScriptCore framework. 关于JavaScriptCore 本教程中所涉及到的几种类型: JSContext, JSContext是代表JS的执行环境,通过-evaluateScript:方法就可以执行一JS代码 JSValue, JSValue封装了JS与ObjC中的对应的类型,以及调用JS的API等 JSExport, JSExpor

iOS与JS交互

① iOS -> JS 原理:通过WebView的方法直接调用JS代码 [WebView stringByEvaluatingJavaScriptFromString:@"A"]; // 这里的 A 就是WebView中的html所对应的JS代码 eg. 1)这里一个html所包含的js文件内的一个public方法 2)这是一个.m(iOS)文件内的一个WebView的调用1)中js方法的写法 3)那么在js的对应方法中,就会得到来自iOS的参数 ② JS -> iOS 原

ios与js交互获取webview元素和赋值

使用webview的stringByEvaluatingJavaScriptFromString的方法交互,直接提供实例. 下载:http://download.csdn.net/detail/heyuan110/4420050 附上document.location.body 属性方法 JS 对象 document:属性 document.title //设置文档标题等价于HTML的<title>标签 document.bgColor //设置页面背景色 document.fgColor /

ios向js传参的方法

在  - (void)webViewDidFinishLoad:(UIWebView *)webView  ; 事件中 [self.webView stringByEvaluatingJavaScriptFromString: @"useLocalPaths()"];    调用html页面的js方法

WKWebView与js交互之完美解决方案

??最近对团队中的混合开发框架进行了重构,下面就和大家来说说自己的思路以及解决方案. ??随着H5功能愈发的强大,没进行过混合开发的小伙们都不好意思说自己能够独立进行iOS的app开发,在iOS7操作系统下,常用的native,js交互框架有easy-js,WebViewJavascriptBridge,以及结合javaScriptCore的框架.easy-js 很早的一个框架了,已经好几年没有人维护了,里面有很多隐藏很深的坑,新人如果没有用过的话,建议不要再用了.主要是js新建一个隐藏的ifr

Objective-c与js交互专题

1     原理 在写 JavaScript 的时候,可以使用一个叫做 window 的对象,像是我们想要从现在的网页跳到另外一个网页的时候,就会去修改 window.location.href 的位置:在我们的 Objective-C 程序码中,如果我们可以取得指定的 WebView 对象,也就可以拿到这个出现在 JavaScript 中的 window 对象,也就是 [webView windowScriptObject]. 这个对象就是 WebView 里头的 JS 与我们的 Object

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

ios js 交互分为两块: 1.oc调用js 这一块实现起来比较简单, 我的项目中加载的是本地的html,js,css,需要注意的是当你向工程中拖入这些文件时,选择如下操作,(拖入的文件夹是蓝色的,相对路径),不然css,js 的路径会存在问题 加载本地html: oc调用js:一句代码搞定 2.js 调用oc js调用oc又分为两种: 1.js端是直接调用方法 这里就要说到ios7才推出的一个新的api    JavaScriptCore,首先我们引入这个类,并初始化一个JSContext对

WebViewJavascriptBridge源码探究--看OC和JS交互过程

今天把实现OC代码和JS代码交互的第三方库WebViewJavascriptBridge源码看了下,oc调用js方法我们是知道的,系统提供了stringByEvaluatingJavaScriptFromString函数 .现在主要是了解js是如何调用oc方法的,分享下探究过程. 源码不多,就一个头文件WebViewJavascriptBridge.h和实现文件WebViewJavascriptBridge.m, 和一个js文件,实现在js那边可以调用oc方法,也可以在oc里面调用js方法. 先