iOS中HTML与OC的交互实现
2016-10-01 00:21
225 查看
近日,由于开发需求,涉及到书写HTML与OC交互的问题。特此做了一番研究,学习到了一点,所以,也就当是做个简单的笔记。希望可以对有需求的人有帮助,就像我自己学习的时候,总是要到处翻书,到处搜索。把这些问题解决掉。
以下为正文内容:
1、HTML与OC交互的关键,在于HTML文件中存在可以响应的点击事件:
如:<input type="button" class="main__button" value="立即抢购" onclick="dealProduct('立即购买')">
onclick是HTML中的点击事件,dealProduct是处理方法,实际上的交互数值,便是调用事件中处理方法返回的数值
2、iOS应用中处理HTML中的事件,需要引入#import
<JavaScriptCore/JavaScriptCore.h> (JavaScriptCore.framework) 这个framework是用来读取HTML中的事件方法的。我用的是UIWebView加载的本地网页视图,在WebViewDidFinishLoad方法中进行交互操作。关键代码如下:
- (void)webViewDidFinishLoad:(UIWebView *)webView {
self.jsContext = [webView valueForKeyPath:@"documentView.webView.mainFrame.javaScriptContext"];
self.jsContext.exceptionHandler = ^(JSContext *context, JSValue *exceptionValue) {
context.exception = exceptionValue;
NSLog(@"异常信息:%@", exceptionValue);
};
以下为正文内容:
1、HTML与OC交互的关键,在于HTML文件中存在可以响应的点击事件:
如:<input type="button" class="main__button" value="立即抢购" onclick="dealProduct('立即购买')">
onclick是HTML中的点击事件,dealProduct是处理方法,实际上的交互数值,便是调用事件中处理方法返回的数值
2、iOS应用中处理HTML中的事件,需要引入#import
<JavaScriptCore/JavaScriptCore.h> (JavaScriptCore.framework) 这个framework是用来读取HTML中的事件方法的。我用的是UIWebView加载的本地网页视图,在WebViewDidFinishLoad方法中进行交互操作。关键代码如下:
- (void)webViewDidFinishLoad:(UIWebView *)webView {
self.jsContext = [webView valueForKeyPath:@"documentView.webView.mainFrame.javaScriptContext"];
self.jsContext.exceptionHandler = ^(JSContext *context, JSValue *exceptionValue) {
context.exception = exceptionValue;
NSLog(@"异常信息:%@", exceptionValue);
};
//dealProduct HTML中对应的点击事件的方法 self.jsContext[@"dealProduct"] = ^(NSString *title){ NSLog(@"返回参数 %@ ",title); }; }大致的一个交互思路就是如此的!个人的简单学习,多有不足,如果不清,可以留言或者加入iOS学习交流群:181798048进行交流。也请大神多加指教。iOS沪上代码小子书
相关文章推荐
- [iOS] 使用WebViewJavascriptBridge实现OC与JS交互
- (0006) iOS 开发之JavaScriptCore 实现UIWebView和HTML的交互
- iOS JS 交互之利用系统JSContext实现 JS调用oc方法
- [iOS] 使用WebViewJavascriptBridge实现OC与JS交互
- iOS JS 交互之利用系统JSContext实现 JS调用oc方法
- iOS之oc与html之间的交互(oc中调用js的方法)
- iOS下Hybird实现---OC与JS交互以及swift与JS交互
- [iOS] 使用WebViewJavascriptBridge实现OC与JS交互
- iOS和JS交互(含OC、html、js)代码不使用第三方库(二)
- iOS OC与JS的交互(WebViewJavascriptBridge实现)
- iOS开发使用WebViewJavascriptBridge实现OC与JS交互
- [iOS] 使用WebViewJavascriptBridge实现OC与JS交互
- IOS中 使用JavaScriptCore 实现OC与JS的交互
- iOS 内嵌html oc与js的交互
- iOS使用WebViewJavascriptBridge实现OC与JS交互
- iOS JS 交互之利用系统JSContext实现 JS调用OC方法以及Objective-C调用JavaScript方法
- [iOS] 使用WebViewJavascriptBridge实现OC与JS交互
- IOS中 使用JavaScriptCore 实现OC与JS的交互
- iOS OC与JS的交互(JavaScriptCore实现)
- iOS开发中,实现UIWebView,html和js之间的交互