//屏蔽右键
- (NSArray *)webView:(WebView *)sender contextMenuItemsForElement:(NSDictionary *)element defaultMenuItems:(NSArray *)defaultMenuItems
{
NSLog(@"fonction==%s\n",__FUNCTION__);
return nil;
}
#pragma mark -
#pragma mark - WebFrameLoadDelegate
//-当页面准备加载新的的URL,调用。
//如果成功,回调 WebResourceLoadDelegate-- willSendRequest
//如果不成功,回调didFailProvisionalLoadWithError
- (void)webView:(WebView *)sender didStartProvisionalLoadForFrame:(WebFrame *)frame
{
NSLog(@"fonction==%s\n",__FUNCTION__);
}
//加载WebResourceLoadDelegate willSendRequest 不成功 出错回调
-(void)webView:(WebView *)sender didFailProvisionalLoadWithError:(NSError *)error forFrame:(WebFrame *)frame
{
NSLog(@"fonction==%s\n",__FUNCTION__);
isBundleHtmlLoad = NO;
}
//-页面完成加载里调用
- (void)webView:(WebView *)sender didFinishLoadForFrame:(WebFrame *)frame
{
NSLog(@"fonction==%s\n",__FUNCTION__);
}
//-系统无法自身完成webView UI加载调用
-(void)webView:(WebView *)sender didFailLoadWithError:(NSError *)error forFrame:(WebFrame *)frame
{
NSLog(@"fonction==%s\n",__FUNCTION__);
}
#pragma mark - WebResourceLoadDelegate
//-保存当前请求的 Http地址
-(NSURLRequest *)webView:(WebView *)sender resource:(id)identifier willSendRequest:(NSURLRequest *)request redirectResponse:(NSURLResponse *)redirectResponse fromDataSource:(WebDataSource *)dataSource
{
if ([request.URL.relativeString hasPrefix:@"http"])
{
histroyURL = request.URL;
}
NSLog(@"fonction==%s\n",__FUNCTION__);
return request;
}
- (void)webView:(WebView *)sender resource:(id)identifier didFinishLoadingFromDataSource:(WebDataSource *)dataSource
{
NSLog(@"fonction==%s\n",__FUNCTION__);
}
//当资源未能加载时调用
- (void)webView:(WebView *)sender resource:(id)identifier didFailLoadingWithError:(NSError *)error fromDataSource:(WebDataSource *)dataSource
{
//忽略未加载完成URL错误
if (error.code == NSURLErrorCancelled)
{
return ;
}
NSLog(@"fonction==%s\n",__FUNCTION__);
[self bundleHtml];
}
- (void)webView:(WebView *)sender plugInFailedWithError:(NSError *)error dataSource:(WebDataSource *)dataSource
{
NSLog(@"fonction==%s\n",__FUNCTION__);
}
#pragma mark - WebPolicyDelegate
- (void)webView:(WebView *)webView unableToImplementPolicyWithError:(NSError *)error frame:(WebFrame *)frame
{
NSLog(@"fonction==%s\n",__FUNCTION__);
}
Mac下开发WebView 中的 JS交互
转自:http://blog.youkuaiyun.com/perry_xiao/article/details/8027249
MacOS开发中WebView已经实现了浏览器的基本功能,使用十分方便,要在WebView中实现JS调用Obj-c的代码个人觉的需要一下几个基本步骤:
1. 要使用WebView需要添加WebKit.framework。
2. 在Window中添加WebView之后需要在右侧属性的connection设置frameLoadDelegate, resourceLoadDelegate, UIDelegate。
3. 定义一个JS中可是别的变量(如external)用于调用Obj-c代码。
4.1 在Obj-c中声明对JS开放的函数。
4.2 建立命名索引。
在JS中只要使用external.Login(account, password)就是调用Obj-c中的[self Login:account password:password]。
5.1 在Obj-c中声明对JS开放的变量,其中Result是Obj-c的变量。5.2 建立变量索引。 如果JS中使用相同的变量名则该函数中可以不再声明。JS中按external.js_result就能访问并修改Obj-c的Result变量。
需要注意的一点是xcode SDK10.7中对变量的索引做的更智能些,而SDK10.6如果JS对Obj-c的变量赋值类型不统一可能会使程序崩溃,因此在SDK从10.7切换到10.6就可能出问题,一种偷懒的方法是将Obj-c的变量定义为id。
上述几个函数是在非正式协议WebScripting中定义的。
实现Obj-c调用JS的代码可以使用如下函数实现,scriptStr中是合法的JS代码:
参考:
Xcode帮助文档中有个CallJS工程实现了这些基本功能。
本文介绍了在MacOS开发中如何在WebView中实现JavaScript与Objective-C的交互。关键步骤包括添加WebKit.framework,设置WebView的代理,定义JS可调用的Objective-C对象,以及声明和实现Objective-C端供JS调用的函数。同时提到了在不同SDK版本间可能存在的兼容性问题,并给出了解决方案。
817

被折叠的 条评论
为什么被折叠?



