如何使用顶部的关闭按钮加载UIWebView?

时间:2010-11-27 08:54:59

标签: iphone uiwebview uinavigationcontroller jquery-mobile

我目前有以下代码从另一个视图加载UIWebView。无论如何我现在有一个关闭按钮?

- (void)tableView:(UITableView *)tableView didSelectRowAtIndexPath:(NSIndexPath *)indexPath {

    UIWebView *webView=[[UIWebView alloc] initWithFrame:CGRectMake(0,0,320,480)];
    [self.view addSubview:webView];
    NSURLRequest *urlRequest;
    NSURL *urlforWebView;
    urlforWebView=[NSURL URLWithString:@"http://www.google.com"];
    urlRequest=[NSURLRequest requestWithURL:urlforWebView];
    [webView loadRequest:urlRequest];

}

我将加载使用jquery mobile构建的页面,因此页面内的关闭按钮也可以正常工作。但在导航栏上是理想的。顺便说一下,我的应用有UINavigationBar

2 个答案:

答案 0 :(得分:11)

我会创建一个新的UIViewController子类,用{n}说WebViewController。然后我会添加一个UINavigationBar,其中包含一个关闭按钮和一个UIWebView。然后,为了显示您的Web视图控制器,您可以执行以下操作:

WebViewController *webViewController = [[WebViewController alloc] init];
webViewController.loadURL = [NSURL URLWithString:@"http://www.google.com"];
[self presentModalViewController:webViewController animated:YES];
[webViewController release];

WebViewController中,您可以定义:

@property (nonatomic, retain) IBOutlet UIWebView *webView;
@property (nonatomic, retain) NSURL *loadURL;

- (IBAction)close:(id)sender;

并实现类似的内容:

- (void)viewDidLoad {
  [super viewDidLoad]

  NSURLRequest *urlRequest = [NSURLRequest requestWithURL:self.loadURL];
  [self.webView loadRequest:urlRequest];
}

- (IBAction)close:(id)sender {
  [self dismissModalViewControllerAnimated:YES];
}

答案 1 :(得分:5)

每当您加载UIWebView时,您都可以先在内容上运行javascript片段。

[webView stringByEvaluatingJavaScriptFromString:@"window.close = function() { window.location = 'app://close-webview'; };"];

这只是劫持了window.close()的正常行为,让你有机会在你的Objective-C中接听电话。

然后在您的UIWebViewDelegate中,您可以收听您选择的任何关闭网址。

- (BOOL)webView:(UIWebView *)webView shouldStartLoadWithRequest:(NSURLRequest *)request navigationType:(UIWebViewNavigationType)navigationType {
    if([request.URL.absoluteString isEqualToString:@"app://close-webview"]) {
        webView.hidden = YES;
        // or whatever you want to do to remove the UIWebView...
        return NO;
    }
    return YES;
}

有点hackish,但它允许Web开发人员从HTML内容中控制关闭按钮的外观。