iOS OC和JS的交互 javaScriptCore方法封装
一、javaScriptCore
javaScriptCore是一种JavaScript引擎,主要为webKit提供脚本处理能力,javaScriptCore是开源webkit的一部分,他提供了强大的整合能力.下面以JS调用OC方法为例,OC调用JS为例说明.
- JSContext, JSContext是代表JS的执行环境,通过-evaluateScript:方法就可以执行一JS代码
- JSValue, JSValue封装了JS与ObjC中的对应的类型,以及调用JS的API等
- JSExport, JSExport是一个协议,遵守此协议,就可以定义我们自己的协议,在协议中声明的API都会在JS中暴露出来,才能调用
二、封装源码
注:JSExport 也可实现JS调用OC方法,但是个人感觉过于复杂,不如直接调用直接
还可以使用WebViewJavascriptBridge第三方库去实现,具体的实现方式根据和后台人员商量决定
根据实用性需求,封装出三个方法,一个初始化(要在UIWebview加载完成方法中创建) 一个JS调用OC的方法(id为JS传给OC的参数,id类型为JSValue数组) 一个是OC调用JS的方法(id为OC传递给JS的参数,类型根据需求定义)
// 初始化
+ (instancetype)bridgeForWebView:(UIWebView *)webView;
// JS调OC
- (void)registerHandler:(NSString *)objcName handler:(JSHandler)handler;
// OC调JS
- (void)callHandler:(NSString*)jsName data:(id)data;
/***********************************WebViewJavascriptBridge.h**********************************/
#import <Foundation/Foundation.h>
#import <UIKit/UIKit.h>
#import <JavaScriptCore/JavaScriptCore.h>
@protocol WebViewJavascriptBridgeProtocol <JSExport>
// 通过JS调用OC方法 (采用代理的方法)
- (void)CallOCFunction;
- (void)CallOCFunctionFirstParameter:(NSString *)parameter;
@end
typedef void(^JSResponseCallback)(id responseData);
typedef void(^JSHandler)(id data);
@interface WebViewJavascriptBridge : NSObject <WebViewJavascriptBridgeProtocol>
// 初始化
+ (instancetype)bridgeForWebView:(UIWebView *)webView;
// JS调OC
- (void)registerHandler:(NSString *)objcName handler:(JSHandler)handler;
// OC调JS
- (void)callHandler:(NSString*)jsName data:(id)data;
@end
/***********************************WebViewJavascriptBridge.m**********************************/
#import "WebViewJavascriptBridge.h"
@interface WebViewJavascriptBridge ()
{
JSContext *_jsContext;
UIWebView *_webView;
}
@end
@implementation WebViewJavascriptBridge
static WebViewJavascriptBridge * gThis = nil;
+ (WebViewJavascriptBridge *) instance
{
if ( gThis == nil ){
static dispatch_once_t onceToken;
dispatch_once(&onceToken, ^{
gThis = [[WebViewJavascriptBridge alloc] init];
});
}
return gThis;
}
+ (instancetype)bridgeForWebView:(UIWebView *)webView {
WebViewJavascriptBridge *bridge = [self instance];
[bridge platformSpecificSetup:webView];
return bridge;
}
- (void)platformSpecificSetup:(UIWebView *)webView {
_webView = webView;
// 对JSContext对象进行初始化
_jsContext = [_webView valueForKeyPath:@"documentView.webView.mainFrame.javaScriptContext"];
// 验证JSContext对象是否初始化成功
_jsContext.exceptionHandler = ^(JSContext *context, JSValue *exception) {
context.exception = exception;
NSLog(@"异常信息:%@", exception);
};
}
#pragma mark - public
// objcName : oc函数名
// handler : block回调
- (void)registerHandler:(NSString *)objcName handler:(JSHandler)handler {
// 创建objcEcho对象赋值给js对象self
// _jsContext[objcName] = self;
// JS调用OC函数
_jsContext[objcName] = ^() {
// 获取JS传来的参数 (JSValue对象数组)
NSArray *args = [JSContext currentArguments];
// 回调
handler(args);
};
}
// jsName : js函数名
// data : 传给js的参数
// responseCallback 回调
- (void)callHandler:(NSString*)jsName data:(id)data {
// OC调用JS函数
JSValue *jsValue = _jsContext[jsName];
// 传字典
// NSDictionary *dict = @{@"key1" : @"参数1", @"key2" : @"参数2"};
// 传对象
// Person *person = [[Person alloc] init];
// JSValue *value = [JSValue valueWithObject:person inContext:_jsContext];
// [value setValue:@"朱凯巍" forProperty:@"name"];
// [value setValue:@(10) forProperty:@"age"];
// OC为JS传参数
[jsValue callWithArguments:@[data]];
}
#pragma mark - JSWebViewObjectProtocol
// 通过JS调用OC方法
- (void)CallOCFunction {
NSLog(@"%s",__func__);
}
- (void)CallOCFunctionFirstParameter:(NSString *)parameter {
NSLog(@"%s",__func__);
}
iOS OC和JS的交互 javaScriptCore方法封装的更多相关文章
- iOS OC与JS的交互(JavaScriptCore实现)
本文包括JS调用OC方法并传值,OC调用JS方法并传值 本来想把html放进服务器里面,然后访问,但是觉得如果html在本地加载更有助于理解,特把html放进项目里 HTML代码 <!DOCTY ...
- OC和JS的交互---JavaScriptCore
JavaScriptCore的简单介绍 JavaScriptCore是iOS7提供的原生框架,可以让Objective-C和JavaScript提供简单直接的交互. JavaScriptCore的使用 ...
- OC与JS的交互(iOS与H5混编)
大神总结WKWebView的坑:https://mp.weixin.qq.com/s/rhYKLIbXOsUJC_n6dt9UfA 在开发过程中,经常会出现需要iOS移动端与H5混编的使用场景. iO ...
- [转]OC与JS的交互详解
事情的起因还是因为项目需求驱动.折腾了两天,由于之前没有UIWebView与JS交互的经历,并且觉得这次在功能上有一定的创造性,特此留下一点文字,方便日后回顾. 我要实现这样一个需求:按照本地的CSS ...
- OC与JS的交互详解
事情的起因还是因为项目需求驱动.折腾了两天,由于之前没有UIWebView与JS交互的经历,并且觉得这次在功能上有一定的创造性,特此留下一点文字,方便日后回顾. 我要实现这样一个需求:按照本地的CSS ...
- OC与JS的交互
现在APP的开发已经不局限于原生开发,很多都是原生+html5这种混合开发 我们可以通过webView这个控件,实现混合开发. 1.首先你需要创建一个html页面 <html> <h ...
- cordova ios --->OC 调用 js (一)
1.在HTML中定义一个函数如OCcallJS() function OCcallJS(){ alert("OC 调用js 的 方法"); } 2.当webview 加载完成的时候 ...
- 前端js重组树形结构数据方法封装
不知道大家平时工作中,有没有遇到这样一种情况:后端接口返回的数据,全都是一维的数组,都是平铺直叙式的数据,业务需求却要你实现树形结构的功能.那么,针对这种情况该怎么办呢?是跟后台好好沟通一下呢,还是沟 ...
- js浮点数保留位数方法封装
大家在平时业务中应该经常跟小数打交道吧,有没有被小数点的保留位数问题搞得头疼啊.比如,保留一位小数,保留俩位小数,保留三位小数,向上取整.四舍五入等等. 而我最近在项目中正好遇到类似的问题:有的地方要 ...
随机推荐
- java执行linux shell命令,并拿到返回值
package com.pasier.xxx.util; import java.io.IOException; import java.io.InputStream; import java.nio ...
- zabbix agent被动模式配置
zabbix agent检测分为主动(agent active)和被动(agent)两种形式,主动与被动的说法均是相对于agent来讨论的.简单说明一下主动与被动的区别如下: 主动:agent请求se ...
- git学习——撤销操作
修改最后一次提交:--amend 在提交完成后发现漏掉了几个文件没有加进去,或者提交信息写错了.想要修改怎么办? 现在可以先把需要修改的信息进行修改如:git add 添加没有添加的文件,vim &l ...
- MyBatis Generator生成DAO——序列化
MyBatis Generator生成DAO 的时候,生成的类都是没有序列化的. 还以为要手工加入(開始是手工加入的),今天遇到分页的问题,才发现生成的时候能够加入插件. 既然分页能够有插件.序列化是 ...
- CTAssetsPickerController 选中图片不显示对号的问题解决
转载自:http://blog.csdn.net/qq_27304667/article/details/53218547 早上AppStore审核通过,下载来看看.突然发现一个选择图片时候选中的标识 ...
- 冰点文库下载器V3.1.4
下载百度文库的利器 http://www.bingdian001.com/?softid=3&ver=3.1.4可以下载
- NSDate 类的总结,全面基础
<span style="font-size:24px;"><span style="font-size:18px;">//1.创建日期 ...
- MySQL5.5中文支持
1. /etc/my.cnf.d/client.cnf [client] #password = [your_password] port = 3306 socket = /tmp/mysql.soc ...
- ubuntu 14.04 anaconda安装
Python的准备工作 Python 一个备受欢迎的点是社区支持很多,有非常多优秀的库或者模块.但是某些库之间有时候也存在依赖,所以要安装这些库也是挺繁琐的过程.但总有人忍受不了这种 繁琐,都会开发出 ...
- tcpdump command
工作中一直在用tcpdump,感觉非常方便,今天心血来潮百度了一下tcpdump的用法,才发现原来还有这么多强大的功能自己都不知道,那叫一个汗啊. 以此文作为备份,记录一些新知道的用法,各位网友谁有新 ...