iOS 与 js交互的其一方法 WebViewJavascriptBridge的使用
#import <WebViewJavascriptBridge.h>
///
@interface ZWBridgeViewController ()<WKNavigationDelegate, WKUIDelegate, UIGestureRecognizerDelegate>
@property (nonatomic, strong) ZWCommonNavBar *navBar;
@property (nonatomic, strong) WKWebView *webView;
@property (nonatomic, strong) WebViewJavascriptBridge *bridge;
@property (nonatomic, copy) NSString *urlStr;
@property (nonatomic, copy) 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;
}
iOS 与 js交互的其一方法 WebViewJavascriptBridge的使用的更多相关文章
- iOS与JS交互实战篇(ObjC版)
前言 ObjectiveC与Js交互是常见的需求,可对于新手或者所谓的高手而言,其实并不是那么简单明了.这里只介绍iOS7.0后出来的JavaScriptCore framework. 关于JavaS ...
- iOS javascript js 交互
//JS里的一个回调.比如网页上的某个按钮点一下之后.JS会调用setKey这个方法. JSContext *context1 = [self.startView valueForKeyPath:@& ...
- ios与js交互获取webview元素和赋值
使用webview的stringByEvaluatingJavaScriptFromString的方法交互,直接提供实例. 下载:http://download.csdn.net/detail/hey ...
- iOS与JS交互-WKWebView
iOS移动端应用中,一般都会嵌入网页,在网页中处理的结果需要反馈给iOS让移动端做出相应的处理(例如页面跳转), 1.webview的配置 2.代理方法中拿到事件进行处理 二.JS中的配套出发事件 当 ...
- android与JS交互,互相调用方法,跳转到网页
在main下面New - Folder - Assets Folder,在Assets下面新建一个js_android.html <html><head> <meta h ...
- html与ios交互方法 WebViewJavascriptBridge
WebViewJavascriptBridge 1.html调用ios的方法 <!DOCTYPE html> <html lang="en"> <he ...
- iOS(WKWebView)OC与JS交互 之三
随着H5功能愈发的强大,没进行过混合开发的小伙们都不好意思说自己能够独立进行iOS的app开发,在iOS7操作系统下,常用的native,js交互框架有easy-js,WebViewJavascr ...
- iOS与JS开发交互总结
hybrid.jpg 前言 Web 页面中的 JS 与 iOS Native 如何交互是每个 iOS 猿必须掌握的技能.而说到 Native 与 JS 交互,就不得不提一嘴 Hybrid. Hybri ...
- OC与JS交互之UIWebView
随着H5的强大,hybrid app已经成为当前互联网的大方向,单纯的native app和web app在某些方面显得就很劣势.关于H5的发展史,这里有一篇文章推荐给大家,今天我们来学习最基础的基于 ...
随机推荐
- CF div2
这是一道二进制思维题: 将所有数字列成二进制形式,然后找出最大的一位“1”出现一次的位数: 然后把这个数提到前面,其他照常输出即可 #include<bits/stdc++.h> usin ...
- kruskal算法生成最小生成树
kurskal算法更适合稀疏图 kruskal算法伪代码: int kruskal(){ 令最小生成树的边权之和为ans, 最小生成树的当前边数为Num_Edge; 将所有边按边权从小到大排序; fo ...
- Oracle中的数据迁移到Mysql数据库中的方式Navicat premium工具
1.安装 Navicat premium工具 2.破解 Navicat premium工具 3.连接需要相互迁移的两个库Mysql和Oracle(可以是远程的或者本机的数据库都是可以的) 4.连接上之 ...
- 95. 不同的二叉搜索树 II、96. 不同的二叉搜索树
95 Tg:递归 这题不能算DP吧,就是递归 一个问题:每次的树都要新建,不能共用一个根节点,否则下次遍历对根左右子树的改动会把已经放进结果数组中的树改掉.. class Solution: def ...
- 解决Cannot download "https://github.com/sass/node-sass/releases/download/binding.nod的问题
npm i node-sass --sass_binary_site=https://npm.taobao.org/mirrors/node-sass/
- 自定义php-mysqli工具增强类,支持链式调用
<?php /*数据库访问类,支持链式访问 *function table($table):表名 *function where($where):条件 *function field(...$f ...
- [Java] 多线程基础详细总结,附加详细实例
详细代码在文章底部 目录 基础概念 进程与线程 单线程与多线程 实现线程的4中方式 thread.start()和runnable.run()的区别 Thread和Runnable的异同 线程的基本操 ...
- 【网易官方】极客战记(codecombat)攻略-地牢-循环又循环
关卡连接: https://codecombat.163.com/play/level/loop-da-loop 循环真是救命恩人! 简介: 你只需要 一个 while true循环 加上 4 条语句 ...
- AcWing 837. 连通块中点的数量
#include <iostream> using namespace std; ; int n, m; int p[N], size[N]; int find(int x) { if ( ...
- springboot 创建子父工程
1.创建子父工程 2.添加pom配置文件 2.1 父工程pom.xml <project xmlns="http://maven.apache.org/POM/4.0.0" ...