2

我有一个表单,用户可以在其中从多选选择框 (A) 中选择一个项目。如果该项目未列出,用户可以从另一个输入文本框 (B) 添加它。在 (B) 中输入的值将执行 ajax 调用,该调用会将项目保存到数据库中。保存项目后,将创建一个 json 对象,然后需要使用更新的列表填充 (A)。我有所有这些与选项一起工作。我现在需要包括保存过程是否通过或失败。如果过程通过,那么我需要包含选项,但如果失败,我只需要失败状态。这是我想出的:

{
    "process": [{
        "status":"pass" ,
        "message":"The Contributors list has been refreshed to contain the entry you just saved." }
    ],
    "newoptions": [
        {"optionValue":"Item 1" , "optionDisplay":"Item 1"},
        {"optionValue":"Item 2" , "optionDisplay":"Item 2" },
        {"optionValue":"Item 3" , "optionDisplay":"Item 3" }
    ]    
}

这就是我在 .ajax 例程中使用的内容:

success: function(j){
    if (j.process.status == 'pass'){
        var options = '';
        for (var i = 0; i < j.newoptions.length; i++) 
            {
                options += '<option value="' + j.newoptions[i].optionValue + '">' + j.newoptions[i].optionDisplay + '</option>';
            }
        $('#misc_userID').val('');  // reset value back to null 
        $("#misc_userID").effect("transfer", { to: $("#group_misc_available") }, 500);  //visual showing item added to select
        $('#group_misc_available').html(options);
    }
    else if (j.status == 'fail'){
        alert(j.process.message);   
    }
}

我没有收到错误,但它也没有处理 j.process.status 所以选择列表(A)没有被刷新..

4

2 回答 2

3

你有array如此process需要访问它index

if (j.process.status == 'pass'){

将会

if (j.process[0].status == 'pass'){
于 2012-10-04T15:33:31.190 回答
3

您没有正确访问您的 json 数据。尝试这个

if (j.process[0].status == 'pass'){
于 2012-10-04T15:33:39.530 回答