21

我的 iOS 应用中有 .html 文件。HTML 文件几乎没有带有 onClick 方法的 div 块。当我点击这些块时,我会在 Web 视图中调用一些 javascript 代码,但我还需要在我的源代码中了解这些事件。

例如,当我点击 web 元素并调用 onClick 时,我需要在代码中调用一些方法,例如- (void)didTouchedWebElementWithId

我可以做这件事吗。谢谢。

4

1 回答 1

48

在 JS 中调用 Objective-C 的方法:

下面的网址有助于做到这一点

如何从 Javascript 调用 Objective C 方法并将数据发送回 iOS 中的 Javascript?

无法执行,我们通过导航到其他页面来解决问题,并且在导航期间,webview 委托将监视导航的前缀并执行我们指定的方法。

示例.html

<html>
    <head>
        <script type='text/javascript'>
            function getText()
            {
                return document.getElementById('txtinput').value;
            }
            function locationChange()
            {
                window.location = 'ios:webToNativeCall';
            }
        </script>
    </head>
    <body style='overflow-x:hidden;overflow-y:hidden;'>
        <h2 style = "font-size:16px;" align='center'>Hi Welcome to Webpage</h2>
        <br/>
        <p align='center' style = "font-size:12px;">Please Click the button after entering the text</p>
        <br/>
        <center>
            <input type='text' style='width:90px;height:30px;' id='txtinput'/>
        </center>
        <br/>
        <center>
            <input type='button' style='width:90px;height:30px;' onclick='locationChange()' value='click me'>
        </center>
    </body>
</html>

Objective-C 代码

当您单击 html 页面中的按钮时,将触发以下委托并取消导航,因为我们返回 NO 并调用相应的方法

- (BOOL)webView:(UIWebView *)webView shouldStartLoadWithRequest:(NSURLRequest *)request navigationType:(UIWebViewNavigationType)navigationType
{
    if ([[[request URL] absoluteString] hasPrefix:@"ios:"]) {

        // Call the given selector
        [self performSelector:@selector(webToNativeCall)];        
        // Cancel the location change
        return NO;
    }
    return YES;
}

- (void)webToNativeCall
{
    NSString *returnvalue =  [self.webviewForHtml stringByEvaluatingJavaScriptFromString:@"getText()"];

    self.valueFromBrowser.text = [NSString stringWithFormat:@"From browser : %@", returnvalue ];
}
于 2013-03-21T07:19:54.737 回答