Is there a bug with using InnerHTML inside a UIWebView within a native iPhone application?

后端 未结 3 2150

I have a fairly large HTML/JS/CSS application that works great when running as a web application with Safari on the iPhone.

When running this same application in an UIWe

3条回答
  •  爱一瞬间的悲伤
    2021-02-08 10:40

    Well, the solution [NOT a production quality solution] posted by Sebastian worked, but I couldn’t confirm if CPU load would cause this issue. I generated a lot of background load on the iOS host and couldn’t reproduce this issue.

    Upon further investigation, the rendering issue seems to be a side effect of iOS shell canceling the navigation. Once the navigation is canceled by the iOS shell, the rendering engine probably take that as not needing to render more UI [basically doesn’t render anything for a small period].

    One way to fix this would be to send commands to iOS shell as hash (#) parameters instead of a URL. This way iOS shell will get the commands and doesn’t need to cancel the navigation. This approach seems to work in the test code below. So, if window.location is set to location1, it alerts “At: 1” and element e2 has no value. And if the window.location is set to location2, it alerts “At: 0” and element e2 has the value.

    @Kevin, could you confirm that you were canceling the navigation on iOS host when this behavior happened.

    Test Code:

    Javascript:

        var location1 = "myApp://Test";
        var location2 = "#myApp://Test";
        $("#change").live("click", function (e) {
            var element = document.getElementById("e1");
            window.location = location1; var i = 0;            
            element.innerHTML = "At: " + i;
            window.__intervalHandle = window.setInterval(function () {
                var html = element.innerHTML;
                if (html) {
                     alert(html);
                    window.clearInterval(window.__intervalHandle);
                    window.__intervalHandle = null;
                } else {
                    element.innerHTML = "At: " + ++i;
                }
            }, 1);
            document.getElementById("e2").innerHTML = "Test";
        });
    

    iOS pseudo code:

    - (BOOL)webView:(UIWebView *)webView shouldStartLoadWithRequest:(NSURLRequest *)request navigationType:(UIWebViewNavigationType)navigationType
    {
    NSURL* u = [ request URL];
    
    if( [[u scheme] compare:@"myapp" ] == NSOrderedSame) {
    { 
    return NO; // don’t navigate
    }
    return YES; // navigate
    }
    

提交回复
热议问题