1

URL付きのテキストボックスの動的リストを取得してサーバーに送信する小さな関数があります。URL を配列にロードしてから、JSON オブジェクトで渡しようとしています。問題は、コードのそのポイントに到達すると、エラーが発生し続けることです。

TypeError: url_data[this_url] is undefined
http://localhost/2011/admin/public/assets/js/tssol.ui.js
Line 196

そのエラーを返すブロックは次のとおりです。

$("#dialogEditor").dialog('option', 'buttons', {'Save' : function() {
    /* Define variables */
    var url_data = new Array();
    var this_url = 0;

    /* I've tried this with and without explicitly passing the vars... */
    $("#website_editor input").each(function(url_data, this_url) {
        var id =$(this).attr('name').match(/\d+/);
        var url=$(this).val();

        /* Test the varible each iteration */
        console.log("this_url: " + this_url + " id: " + id + " url: " + url);

    /* Line 196 */ url_data[this_url].id = id;
        url_data[this_url].url = url;

        this_url++;
});


data = JSON.stringify(url_data);
//data = url_data;
//console.log(data);

$.ajax({
    url: 'ajax.websites.php',
    dataType: 'json',
    data: {
        action: "update_resort",
        ResortId: resort,
        data: data
    }
});

$(this).dialog("close");
},
'Cancel': function(){$(this).dialog("close");
}});
},

整形でごめんなさい

4

1 に答える 1

3

私はこれを行います:

url_data[this_url] = {
    id: id,
    url: url
}
于 2012-10-17T18:00:28.530 に答える