oc与js的简单交互

1.用本地的html来测试,先写一个html

index.html:

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>oc与js交互</title>
    <script type="text/javascript" src="index.js"></script>
</head>
<body>
<button onclick="hello()">这是按钮</button>
<button id="button" onclick="buttonFun('传参') ">这是按钮1</button>

</body>
</html>

index.js:

function hello() {
    alert("hello")
}

var param = "demo";
function buttonFun(param){
    alert(param)
}

在.m导入
#import <JavaScriptCore/JavaScriptCore.h>

加载本地的html

NSString *path = [[NSBundle mainBundle] bundlePath];
NSURL *baseURL = [NSURL fileURLWithPath:path];
NSString * htmlPath = [[NSBundle mainBundle] pathForResource:@"index"
                                                      ofType:@"html"];
NSString * htmlCont = [NSString stringWithContentsOfFile:htmlPath
                                                encoding:NSUTF8StringEncoding
                                                   error:nil];
[self.webView loadHTMLString:htmlCont baseURL:baseURL];
self.webView.delegate = self;

3.交互
思路:
1.先和前端同事规定好函数名称和传参的类型
2.通过函数名,来进行oc的代码操作
3.oc代码操作结束后,把结果传给h5

-(void)webViewDidFinishLoad:(UIWebView *)webView
{
//网页加载完成调用此方法
//首先创建JSContext 对象(此处通过当前webView的键获取到jscontext)
JSContext *context=[webView valueForKeyPath:@"documentView.webView.mainFrame.javaScriptContext"];
//获取函数名称
context[@"hello"] = ^(){
    //进行iOS这边的逻辑操作 
    NSLog(@"_____get identify__________");
    //操作结束,把结果传给h5 buttonFun为接受结果的函数名称 
    NSString *smethods = [NSString stringWithFormat:@"%@('%@')", @"buttonFun", @"打印结束"];
    [webView stringByEvaluatingJavaScriptFromString:smethods];
};
}
CE23FC8B-E460-4873-9A0B-9FF1DD2956C8.png
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • H5的快速发展,使得现在各种APP中或多或少的嵌入了H5的页面,那么原生页面和H5的混合开发成了我们不得不熟悉的...
    RainyHand阅读 2,499评论 4 13
  • 随着H5技术的兴起,在iOS开发过程中,难免会遇到原生应用需要和H5页面交互的问题。其中会涉及方法调用及参数传值等...
    Chris_js阅读 3,125评论 1 8
  • 一、说明 这篇文章记录自己在研究OC与JS交互中的所得,以及遇到的问题与解决 由于苹果的审核时间太漫长,一次审核不...
    xukunluren阅读 885评论 1 7
  • 只有根扎的深,才会枝繁叶茂——而这需要很长一段路,韬光养晦,默默无闻。灿烂繁华的背后,一定有寂寞孤独的坚持。 塑造...
    蓝色的海sunshine阅读 177评论 0 0
  • 今天分享点比较基础的东西,别小看这基础的东西,面试时,一个小小的知识点,有时能决定你是否被录用。笔者两年前就因为一...
    洪生鹏阅读 3,761评论 2 17