JQuery AJAX внутри проблемы цикла - PullRequest
18 голосов
/ 22 апреля 2010

Этот скрипт js цикла всегда получает последнее значение ui_item внутри функции jquery ajax Как можно поймать правильное значение каждой итерации?

for (var i = 0; i <= split_files_cb_value_holder.length - 1; i++){
    var split_values = split_files_cb_value_holder[i].split(':');

    ui_item = split_files_cb_value_holder[i];

    $.ajax({
        type: "POST",
        url: "ds/index.php/playlist/check_folder",
        data: "component_type="+$('#component_type').val()+"&value="+split_values[1],
        success: function(msg)
        {
            console.log(ui_item); //ALWAYS GETS THE LAST VALUE
        },
        error: function()
        {
            alert("An error occured while updating. Try again in a while");
        }
    });

}

Спасибо! * * 1004

Ответы [ 2 ]

47 голосов
/ 22 апреля 2010

Проблема в том, что анонимный метод обратного вызова перехватывает переменную ui_item по ссылке. Поскольку существует только одна переменная, она всегда получает то, что было назначено последней переменной.

Вам нужно обернуть содержимое цикла for в функцию, которая принимает i в качестве параметра, а затем вызвать функцию в цикле. Каждый вызов функции-оболочки создает отдельную переменную, решая проблему.

Например:

function doCheck(i) {
    var split_values = split_files_cb_value_holder[i].split(':');

    var ui_item = split_files_cb_value_holder[i];

    $.ajax({
        type: "POST",
        url: "ds/index.php/playlist/check_folder",
        data: "component_type="+$('#component_type').val()+"&value="+split_values[1],
        success: function(msg)
        {
            console.log(ui_item); //Don't always get the last value
        },
        error: function()
        {
            alert("An error occured while updating. Try again in a while");
        }
    });
}

for (var i = 0; i < split_files_cb_value_holder.length; i++) 
    doCheck(i);
0 голосов
/ 19 июля 2011

Выключите асинхронный режим, я думаю, это решит проблему.Я имею в виду добавить это: async: false

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...