UIWebView --app 调用 js

本文介绍了在iOS中UIWebView如何调用JavaScript进行交互。由于iOS9默认禁止加载HTTP请求,需要修改info.plist来解除限制。同时,从iOS7开始,JavaScriptCore.framework使得JS与Objective-C的交互更便捷。文中展示了导入JavaScriptCore框架、设置UIWebView及实现代理方法的步骤,以实现Web页面与app的交互功能。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

UIWebView –app 调用 js

web页面和app直接的交互是很常见的东西。ios的WebView有两个类,一个叫UIWebView,另一个是WKWebView。

ios9默认是不允许加载http请求的,对于web view,加载http网页也是不允许的。

可以通过修改info.plist取消http限制

在项目中找到info.plist,以source code方式打开,添加下面的内容

<key>NSAppTransportSecurity</key>
<dict>
    <key>NSAllowsArbitraryLoads</key>
    <true/>
</dict>

从IOS7开始,苹果公布了JavaScriptCore.framework ,它似的JS与OC的交互更加方便了。下面就简单了解下这个框架。

1. 首先导入framework,方法如下:
这里写图片描述

2.点击”Linked Frameworks and Libraries”,选择“JavaScriptCore.framework”
这里写图片描述

3.在viewController中导入头文件

#import <JavaScriptCore/JavaScriptCore.h>

4.在ViewController中创建一个UIWebView用来测试

@interface ViewController()<UIWebViewDelegate>
@property(nonatomic,strong)UIWebView *myWebView;
@end

@implementation ViewController
-(void)viewDidLoad{
    self.myWebView = [UIWebView alloc] initWithFrame:CGRectMake(0,22,[UIScreen mainScreen].bounds.size.width,[UIScreen mainScreen].bounds.size.height-22)];

self.myWebView.delegate = self;
[self.view addSubView:self.myWebView];

//网址
NSString *httpStr = @"http://www.baidu.com";
NSURL *url = [NSURL URLWithString:httpStr];
NSURLRequest *request = [NSURLRequest requestWithURL:url];

[self.myWebView loadRequest:request];
}

5.添加协议

@interface ViewController()<UIWebViewDelegate>

实现UIWebViewDelegate代理方法

#pragma mark --webViewDelegate
-(void)webViewDidFinishLoad:(UIWebView*)webView{
    //网页加载完成调用此方法
    //首先创建JSContext对象(此处通过webView的键获取到jscontext)
    JSContext *context = [webView valueForKeyPath:@"documentView.webView.mainFrame.javaScriptContext"];
    //准备执行的js代码
    NSString *alertStr = @"alert('vic test invoke js')";
    //通过oc方法调用js的alert
    [context evaluateScript:alertStr];
}

运行效果如下:
这里写图片描述

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值