调用外部函数后,JQuery循环停止

时间:2013-11-08 05:05:14

标签: jquery loops

我有一个带循环的函数调用(如果条件为真)另一个函数.push()它将数据作为对象返回到数组中。 发生的事情是,在第一次调用第二个函数之后,第一个函数的循环停止,代码移动到代码的下一部分(在chrome控制台中没有错误,我得到正确的对象被推送)。 有什么问题?

第一个功能:

    if (window.localStorage.length > 1) {
        track_items_for_chart = [];
        for (i = 0; i < window.localStorage.length; i++) {
            console.log(i);
            var key_name = (window.localStorage).key(i);
            var record_time = (window.localStorage.getItem(key_name));
            if (record_time !== '[]') {
                console.log("record_time !== '[]'");
                if (key_name !== 'exp') {
                    console.log("key_name !== 'exp'");
                    if (key_name !== 'ripple-last-load') {
                        console.log("key_name !== 'ripple-last-load'");
                var computed_info = get_total_km(key_name);
                    }

                }


            }
        }

第二功能:

function get_total_km($object_key) {

    // Get all the GPS data for the specific workout
    var data = window.localStorage.getItem($object_key);

    // Turn the stringified GPS data back into a JS object
    data = jQuery.parseJSON(data);
    if (data) {
        // Calculate the total distance travelled
        total_km = 0;
        for (i = 0; i < data.length; i++) {

            if (i === (data.length - 1)) {
                break;
            }

            total_km += gps_distance(data[i].coords.latitude, data[i].coords.longitude, data[i + 1].coords.latitude, data[i + 1].coords.longitude);
        }

        total_km_rounded = parseFloat(total_km.toFixed(2));
        // Calculate the total time taken for the track
        start_time = new Date(data[0].timestamp).getTime();
        end_time = new Date(data[data.length - 1].timestamp).getTime();
        total_time_ms = end_time - start_time;
        total_time_s = total_time_ms / 1000;
        final_time_m = Math.floor(total_time_s / 60);
        final_time_s = Math.floor(total_time_s - (final_time_m * 60));
//        console.log({total_km_rounded: total_km_rounded, final_time_m: final_time_m, final_time_s: final_time_s});
        var time_mas = parseFloat(final_time_m + "." + final_time_s);
        track_items_for_chart.push(total_km_rounded, time_mas);
    }
}

1 个答案:

答案 0 :(得分:1)

ּ在两个函数中以for( var i =0)开头。如果您习惯使用其他语言,这有点令人困惑,但JS表示所有i(直到您使用var定义它们)为相同的参数。所以在第二个函数运行后,我已经大于你的本地存储长度了。

您需要阅读有关JS参数范围的更多信息;

也许从这里开始:What is the scope of variables in JavaScript?