OC与JS交互UIWeView(一)

        随着h5的兴起,原生app与h5页面交互的场合越来越多,UIwebView相对于WkWebView已经非常成熟用法也非常简单无需配置,下面我来介绍一下在UIWebView下与js的简单方法调用

在UIWebView中与js交互还需要借用JavaScriptCore

1,新建一个OC工程

2,在页面加入一个UIWebView控件,并且实现代理。

//是否允许html页面加载或者跳转,可在此处根据navigationType或者request拦截页面跳转类型
- (BOOL)webView:(UIWebView *)webView shouldStartLoadWithRequest:(NSURLRequest *)request navigationType:(UIWebViewNavigationType)navigationType{
    return YES;
}
//页面开始加载
- (void)webViewDidStartLoad:(UIWebView *)webView{
    
}
//页面加载结束
- (void)webViewDidFinishLoad:(UIWebView *)webView{

}
//页面加载失败
- (void)webView:(UIWebView *)webView didFailLoadWithError:(NSError *)error{
    
}

3,写一个简单的html文件并且包含JavaScript语言

<html>
<header>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<script type="text/javascript">

function jsAlert()
{
    alert('这是JS方法弹出框');
}

function JStoOC(){
    OCAlert();
}

</script>
</header>

<body>
<br/>
<h2> 这里是一个HTML页面 </h2>
<br/>
<form name="myform" οnsubmit="return JStoOC()">
<button type="submit">去调用OC弹出框</button>
</form>
</body>
</html>


4,在OC文件里面调用js和接收js回调处理,记得首先引入js框架

#import <JavaScriptCore/JavaScriptCore.h>

//页面加载结束
- (void)webViewDidFinishLoad:(UIWebView *)webView{
    JSContext *context = [self.webView valueForKeyPath:@"documentView.webView.mainFrame.javaScriptContext"];
    context[@"JStoOC"] = ^() {//接收js的回调,其中JStoOC即为方法名如果有参数可在^()中加入
        [self OCAlert];
    };
}
//页面加载失败
- (void)webView:(UIWebView *)webView didFailLoadWithError:(NSError *)error{
    
}

- (IBAction)onClickToJSAlert:(UIButton *)sender {
    JSContext *context = [self.webView valueForKeyPath:@"documentView.webView.mainFrame.javaScriptContext"];
    [context evaluateScript:@"jsAlert()"];//调用js方法jsAlert即为js方法名
}

- (void)OCAlert{
    UIAlertAction *action = [UIAlertAction actionWithTitle:@"OK" style:UIAlertActionStyleDefault handler:^(UIAlertAction * _Nonnull action) {
        
    }];
    UIAlertController *alertVC = [UIAlertController alertControllerWithTitle:@"OC" message:@"这是OC弹出框" preferredStyle:UIAlertControllerStyleAlert];
    [alertVC addAction:action];
    [self presentViewController:alertVC animated:YES completion:nil];
}


5,demo地址下载http://download.csdn.net/detail/u010067452/9746291




  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值