Logo Questions Linux Laravel Mysql Ubuntu Git Menu
 

javascript event Handler in uiwebview

I am displaying one UIWebView in my iPhone application. In UIWebView I am displaying HTML page which has JavaScript also. I want to call method(of X Code) when one button is clicked in HTML page.

How can I do this. Thanks

like image 900
Royal Pinto Avatar asked Jul 29 '11 05:07

Royal Pinto


2 Answers

If I understand your question correctly, you want to call an Objective C method from a javascript onClick event handler in your UIWebView. The way to do that is to redirect the browser to a URL with a custom scheme in your javascript code like this:

function buttonClicked() {
    window.location.href = "yourapp://buttonClicked";
}

Back in Objective C, declare that your view controller conforms to the UIWebViewDelegate protocol,

@interface DTWebViewController : DTViewController <UIWebViewDelegate> {
...

set your controller as the web view's delegate,

- (void)viewDidLoad {
    [super viewDidLoad];
    self.webView.delegate = self;
}

and intercept the URL before it loads like this:

- (BOOL)webView:(UIWebView *)webView shouldStartLoadWithRequest:(NSURLRequest *)request navigationType:(UIWebViewNavigationType)navigationType {
    if ([[request.URL scheme] isEqual:@"yourapp"]) {
        if ([[request.URL host] isEqual:@"buttonClicked"]) {
            [self callYourMethodHere];
        }
        return NO; // Tells the webView not to load the URL
    }
    else {
        return YES; // Tells the webView to go ahead and load the URL
    }
}
like image 105
cduhn Avatar answered Nov 04 '22 06:11

cduhn


Swift Version

webView.delegate = self

extension ViewController: UIWebViewDelegate {
    func webView(_ webView: UIWebView, shouldStartLoadWith request: URLRequest, navigationType: UIWebViewNavigationType) -> Bool {
        if request.description == "yourappname://buttonClicked" {

            // do your stuff here
            return false
        }
        return true
    }    
}

Example HTML

<a href="yourappname://buttonClicked">
    <img src="http://someurl.com/table_desktop.jpg"/ width="100%">
</a>

If you want to know how to do it in wkWebView, here is the link

like image 36
noob Avatar answered Nov 04 '22 06:11

noob