为什么这会导致无限循环?

时间:2014-09-02 03:46:39

标签: javascript json loops

我是JavaScript的新手,我正在尝试制作一个简单的脚本。基本上,我希望它能够在名为ROBLOX的网站上找到商品的最低价格。出于某种原因,这个脚本导致无限循环,导致我的Chrome崩溃。任何人都可以帮忙

function getLowest(id) {
    var give;
    for (var page = 1; page < 33; page++) {
        var link = "http://www.roblox.com/catalog/browse.aspx?CatalogContext=1&Subcategory=9&CurrencyType=0&pxMin=0&pxMax=0&SortType=0&SortAggregation=3&SortCurrency=0&PageNumber=" + page + "&IncludeNotForSale=false&LegendExpanded=true&Category=3";
        $.get(link, function(data) {
            for (var item in data) {
                if (data[item]["AssetId"] == id) {
                    give = data[item]["BestPrice"];
                }
            }
        })
    }
    if (give) {
        return give;
    }
}

console.log(getLowest(prompt("Enter the ID to find the lowest price of")));

2 个答案:

答案 0 :(得分:0)

我真的想通了,谢谢你的帮助。

这就是我最终的结果:

function getLowest(id) {
    for (var page = 1; page < 33; page++) {
        var link = "http://www.roblox.com/catalog/json?browse.aspx?CatalogContext=1&Subcategory=9&CurrencyType=0&pxMin=0&pxMax=0&SortType=0&SortAggregation=3&SortCurrency=0&PageNumber=" + page + "&IncludeNotForSale=false&LegendExpanded=true&Category=3";
        $.get(link, function(data) {
            for (var item in data) {
                if (data[item]["AssetId"] == id) {
                    console.log(data[item]["BestPrice"]);
                    return;
                }
            }
        })
    }
}

getLowest(prompt("Enter the ID to find the lowest price of"));

答案 1 :(得分:0)

您没有遇到无限循环问题,而是出现异步加载问题。

for (var page = 1; page < 33; page++) {
    $.get(link, function(data) {
        for (var item in data) {
            if (data[item]["AssetId"] == id) {
                give = data[item]["BestPrice"];
            }
        }
    })
}

假设您使用jQuery&#39; $.get来查询这些页面,$.get的默认行为是异步查询页面。因此,这个循环将完成而不等待被调用$.get中的所有回调,这表明退出循环时give将保持未定义。

解决方案将是您在答案中建议的解决方案,或

  • 使用$.get&#39;
  • 强制$.ajax({ url: link, async: false }).done(function(data) {})同步
  • 使用async.js执行异步收集,并在完成所有查询工作后使用回调重写该函数。