Javascript IOS5 "JavaScript execution exceeded timeout"

标签 javascript ios5

以下测试基本上是 ~1000 次数学运算,并且在大多数 PC 和 android 浏览器以及 iOS 4.x 上运行良好。在 iOS5 safari(iPhone 4 和 iPad 2)上,我们得到“JavaScript:错误未定义的 JavaScript 执行超出超时”。非常感谢任何帮助。

/** Converts numeric degrees to radians */
if (typeof (Number.prototype.toRad) === "undefined") {
    Number.prototype.toRad = function () {
    return this * Math.PI / 180;
    }
}

function gc(lat1, lon1, lat2, lon2) {
    // returns the distance in km between a pair of latitude and longitudes
    var R = 6371; // km
    var dLat = (lat2 - lat1).toRad();
    var dLon = (lon2 - lon1).toRad();
    var a = Math.sin(dLat / 2) * Math.sin(dLat / 2) +
        Math.cos(lat1.toRad()) * Math.cos(lat2.toRad()) *
        Math.sin(dLon / 2) * Math.sin(dLon / 2);
    var c = 2 * Math.atan2(Math.sqrt(a), Math.sqrt(1 - a));
    var d = R * c;
    return d;
}

function test() {
    var d1 = new Date();
    var lat1, lon1, lat2, lon2;
    lat1 = -36;
    lon1 = 174;

    lat2 = lat1;
    lon2 = lon1;

    while (lat2 > -37) {
    lat2 = lat2 - 0.001;
    var stest = "lat1=" + lat1 + ",lon1=" + lon1 + ",lat2=" + lat2 + ",lon2=" + lon2 + "=" + gc(lat1, lon1, lat2, lon2);

    }
    var d2 = new Date();
    var stest = (d2.getTime() - d1.getTime()) / 1000.0 + "s";
    $("#lblTest").html(stest + "<BR/>" + $("#lblTest").html());

}

最佳答案

如果你想在 javascript 中执行一个长时间运行的操作,并且你正在接近某些浏览器强制执行的脚本执行时间限制,那么你将不得不将你的函数分成多个部分,运行一个部分,直到一个非常short setTimeout(fn, 1) 然后执行下一段,等等...这样做,您可以运行代码数小时,因为它为其他脚本和其他事件提供了处理的机会。有时需要少量的代码重组才能做到这一点,但只要稍加努力就可以实现。

伪代码的基本概念是这样的:

var state = {};   // set initial state
var done = false;

function doWork() {
   // do one increment of work that will never get even close to the browser
   // execution time limit
   // update the state object with our current operating state for the next execution
   // set done = true when we're done processing
   if (!done) {
       setTimeout(doWork, 1);
   }
}

doWork();

在您的特定代码中,您可以这样做。您可以一次处理 100 个纬度点,然后执行一个简短的 setTimeout 来执行下一个 100 个,依此类推。您可以将该 100 数字调整为最有效的数字。数字越高,您在每个计时器上执行的操作越多,整体执行时间越长,但您越接近浏览器脚本执行限制。 setTimeout 使浏览器保持事件状态(处理其他事件)并防止执行时间限制生效。

function test() {
    var d1 = new Date();
    var lat1, lon1, lat2, lon2, done = false;;
    lat1 = -36;
    lon1 = 174;

    lat2 = lat1;
    lon2 = lon1;

    function calcGC() {
        var cntr = 0;
        while (lat2 > -37 && cntr < 100) {
            lat2 = lat2 - 0.001;
            var stest = "lat1=" + lat1 + ",lon1=" + lon1 + ",lat2=" + lat2 + ",lon2=" + lon2 + "=" + gc(lat1, lon1, lat2, lon2);
            cntr++;
        }
        // if we have more to go, then call it again on a timeout
        if (lat2 > -37) {
            setTimeout(calcGC, 1);
        } else {
            var d2 = new Date();
            var stest = (d2.getTime() - d1.getTime()) / 1000.0 + "s";
            $("#lblTest").html(stest + "<BR/>" + $("#lblTest").html());
        }
    }
    calcGC();
}

关于Javascript IOS5 "JavaScript execution exceeded timeout",我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/7787219/

相关文章:

javascript - 正则表达式避免数字和特殊字符并允许单词之间有空格

javascript - 错误: Unreachable code detected ionic 3 weather app

javascript - 我如何调查 jQuery 中的 HTML 限制?

iphone - 如何更改 Root View Controller

javascript - 在 polymer 元素中加载网页字体的正确方法是什么

xcode - TouchUpInside 在 iOS5 上没有响应

ios - 如何更改核心数据中的记录值

iphone - iOS 5 UIWindow makeKeyAndVisible 关闭模态

xcode - 当附件为UITableViewCellAccessoryCheckmark时如何在UITableViewCell中居中放置文本

javascript - 如何在 Highcharts 中设置默认多选?