首页 > 代码库 > OC 和 js 交互
OC 和 js 交互
首先导入
<style>p.p1 { margin: 0.0px 0.0px 0.0px 0.0px; font: 14.0px Menlo; color: #d12f1b } span.s1 { color: #78492a } span.s2 { }</style>#import <JavaScriptCore/JavaScriptCore.h>
声明 对象
<style>p.p1 { margin: 0.0px 0.0px 0.0px 0.0px; font: 14.0px Menlo; color: #bb2ca2 } span.s1 { } span.s2 { color: #000000 } span.s3 { color: #703daa }</style>@property (nonatomic, strong) JSContext *context;
1, oc调用js的方法并获取参数
<style>p.p1 { margin: 0.0px 0.0px 0.0px 0.0px; font: 14.0px Menlo } p.p2 { margin: 0.0px 0.0px 0.0px 0.0px; font: 14.0px Menlo; min-height: 16.0px } p.p3 { margin: 0.0px 0.0px 0.0px 0.0px; font: 14.0px Menlo; color: #d12f1b } p.p4 { margin: 0.0px 0.0px 0.0px 0.0px; font: 14.0px Menlo; color: #4f8187 } span.s1 { } span.s2 { color: #bb2ca2 } span.s3 { color: #703daa } span.s4 { color: #000000 } span.s5 { color: #4f8187 } span.s6 { color: #3d1d81 } span.s7 { color: #d12f1b }</style>- (void)webViewDidFinishLoad:(UIWebView *)webView{
//初始化 context
self.context = [webView valueForKeyPath:@"documentView.webView.mainFrame.javaScriptContext"];
__block JJMessageViewController *messageSelf = self;
// details 是js的方法
self.context[@"details"] = ^{
NSArray *arg = [JSContext currentArguments];
//获取的参数 也可以是id类型 (这里是将jsvalue转换成nsstring)
for (JSValue *jsVal in arg) {
NSLog(@"%@", jsVal.toString);
//jsVal.toString 就是js传递的参数(这里是字符串) 也可以是一个数组或者字典
messageSelf.messageTitle = jsVal.toString;
}
};
}
剩下的就在下面的这个方法中操作
<style>p.p1 { margin: 0.0px 0.0px 0.0px 0.0px; font: 14.0px Menlo } p.p2 { margin: 0.0px 0.0px 0.0px 0.0px; font: 14.0px Menlo; color: #703daa } p.p3 { margin: 0.0px 0.0px 0.0px 0.0px; font: 14.0px Menlo; color: #d12f1b } p.p4 { margin: 0.0px 0.0px 0.0px 0.0px; font: 14.0px Menlo; min-height: 16.0px } p.p5 { margin: 0.0px 0.0px 0.0px 0.0px; font: 14.0px Menlo; color: #4f8187 } p.p6 { margin: 0.0px 0.0px 0.0px 0.0px; font: 14.0px Menlo; color: #3d1d81 } p.p7 { margin: 0.0px 0.0px 0.0px 0.0px; font: 14.0px Menlo; color: #bb2ca2 } span.s1 { } span.s2 { color: #bb2ca2 } span.s3 { color: #703daa } span.s4 { color: #000000 } span.s5 { color: #3d1d81 } span.s6 { color: #d12f1b } span.s7 { color: #4f8187 }</style>- (BOOL)webView:(UIWebView *)webView shouldStartLoadWithRequest:(NSURLRequest *)request navigationType:(UIWebViewNavigationType)navigationType {
NSString *str = request.URL.absoluteString;;
NSLog(@"url --- %@",str);
NSRange range = [str rangeOfString:@"ios://jwzhangjie"];
if (range.location != NSNotFound)
{
//这里操作其他动作
return false;
}
return YES;
}
2. oc传参数给js (触发按钮点击事件里面操作)
<style>p.p1 { margin: 0.0px 0.0px 0.0px 0.0px; font: 14.0px Menlo } p.p2 { margin: 0.0px 0.0px 0.0px 0.0px; font: 14.0px Menlo; min-height: 16.0px } p.p3 { margin: 0.0px 0.0px 0.0px 0.0px; font: 14.0px Menlo; color: #3d1d81 } span.s1 { } span.s2 { color: #bb2ca2 } span.s3 { color: #703daa } span.s4 { color: #4f8187 } span.s5 { color: #d12f1b } span.s6 { color: #3d1d81 } span.s7 { color: #272ad8 } span.s8 { color: #000000 }</style>
- (void)deleteBtnClick:(UIButton *)sender
{
//deleAll是js的方法
JSValue * function = context[@"deleAll"];
//delete是要传递给js的参数
JSValue *result = [function callWithArguments:@[@"delete"]];
//让js用一个弹出框弹出delete
}
目前用到这些 自己总结的 不对的请大家多多指教
<style>p.p1 { margin: 0.0px 0.0px 0.0px 0.0px; font: 14.0px Menlo } span.s1 { } span.s2 { color: #703daa }</style>OC 和 js 交互