Force a WebView link to launch Safari?

前端 未结 5 2046
广开言路
广开言路 2020-12-04 08:28

I have a UIWebView embedded within an iPhone app of mine. I want to be able to have certain links within that webview open into the full Mobile Safari app (i.e. not my embed

相关标签:
5条回答
  • 2020-12-04 09:02

    This is how we solved it, add this to your ViewController.m file:

        - (void)viewDidLoad
    {
        [super viewDidLoad];
        // Do any additional setup after loading the view, typically from a nib.
        first.delegate = (id)self;
                    [first loadRequest:[NSURLRequest requestWithURL:[NSURL     URLWithString:@"http://my.FellowshipNWA.org?publicapp"]]];
    }
    
    // Add section below so that external links & PDFs will open in Safari.app
    - (BOOL)webView:(UIWebView *)webView shouldStartLoadWithRequest:(NSURLRequest *)request     navigationType:(UIWebViewNavigationType)navigationType {
        if (navigationType == UIWebViewNavigationTypeOther) {
            NSString *checkURL = @"http://my.fellowshipnwa.org/?givenowsafari";
            NSString *reqURL = request.URL.absoluteString;
            if ([reqURL isEqualToString:checkURL])
                 {
                     [[UIApplication sharedApplication] openURL:request.URL];
                return false;
        }
            else {
                return true;
            }
        }
        return true;
    }
    
    0 讨论(0)
  • 2020-12-04 09:05

    I haven't tried this myself but I think that you can implement the UIWebViewDelegate method

    webView:shouldStartLoadWithRequest:navigationType 
    

    which will be called anytime a link in the UIWebView is clicked on. In that method you just need to determine if the clicked link should result in launching Safari or not and use openURL if it should.

    - (BOOL)webView:(UIWebView *)webView shouldStartLoadWithRequest:(NSURLRequest *)request navigationType:(UIWebViewNavigationType)navigationType {
    
        // Check if this was a click event and then some other criteria for determining if you want to launch Safari.
        if (navigationType == UIWebViewNavigationTypeLinkClicked && [Some other criteria]) {
            [[UIApplication sharedApplication] openURL:request.URL];
    
            // Return false to indicate to the UIWebView to not navigate to the linked target
            return false;
        }
    
        // Return true so that the UIWebView loads the link target
        return true;
    }
    

    Don't forget that you need to set your UIWebView delegate property to an instance of the class that implements the UIWebViewDelegate.

    0 讨论(0)
  • 2020-12-04 09:07

    Swift version of Brad Larson's answer:

    func webView(webView: UIWebView, shouldStartLoadWithRequest request: NSURLRequest, navigationType: UIWebViewNavigationType) -> Bool {
    
        var url: NSURL = request.URL!
        var isExternalLink: Bool = url.scheme == "http" || url.scheme == "https" || url.scheme == "mailto"
        if (isExternalLink && navigationType == UIWebViewNavigationType.LinkClicked) {
            return !UIApplication.sharedApplication().openURL(request.URL!)
        } else {
            return true
        }
    }
    
    0 讨论(0)
  • 2020-12-04 09:14

    To expand upon what Randy said, this is what I use in my application to make every http://, https://, and mailto:// URL open in the external Safari or Mail applications:

    -(BOOL)webView:(UIWebView *)webView shouldStartLoadWithRequest:(NSURLRequest *)request navigationType:(UIWebViewNavigationType)navigationType; 
    {
        NSURL *requestURL =[ [ request URL ] retain ]; 
        if ( ( [ [ requestURL scheme ] isEqualToString: @"http" ] || [ [ requestURL scheme ] isEqualToString: @"https" ] || [ [ requestURL scheme ] isEqualToString: @"mailto" ]) 
            && ( navigationType == UIWebViewNavigationTypeLinkClicked ) ) { 
            return ![ [ UIApplication sharedApplication ] openURL: [ requestURL autorelease ] ]; 
        } 
        [ requestURL release ]; 
        return YES; 
    }
    

    As Randy says, you'll want to implement this within whatever class you set to be the delegate of the UIWebView. To have only select URLs launch Safari, you could change their scheme from http:// to safari://, or something similar, and only kick those URLs off to the system (after replacing the custom URL scheme with http://).

    I do this within my internal help documentation, which is HTML displayed in a UIWebView, so that I don't run into issues in the review process with having a general-purpose web browser embedded in my application.

    0 讨论(0)
  • 2020-12-04 09:18

    Ok I got it. Maybe its not the perfect solution, but you can do it like this:

    Only in your WebViewController.m:

    add the line webView.delegate = self; to the viewDidLoad procedure:

    - (void)viewDidLoad {
        webView.delegate = self;
        .... your code ....
    }
    

    Then you can add as described above somewhere in the Controller.m File following boolean resulting function:

    - (BOOL)webView:(UIWebView *)webView shouldStartLoadWithRequest:(NSURLRequest *)request navigationType:(UIWebViewNavigationType)navigationType {
        if (navigationType == UIWebViewNavigationTypeLinkClicked) {
            [[UIApplication sharedApplication] openURL:request.URL];
            return false;
        }
        return true;
    }
    
    0 讨论(0)
提交回复
热议问题