extjs 从form.submit而不是Store阅读PHP响应中的嵌套JSON

oymdgrw7  于 2022-11-05  发布在  PHP
关注(0)|答案(1)|浏览(162)

我正在使用ExtJS 6.0.x构建一个Web应用程序。在一个部分中,用户可以上传一个Excel文件,然后我将解析它并将数据保存到后端。
我为上传和解析调用的PHP返回一个嵌套的JSON对象,其结构如下所示:

{
    "success":false,
    "message":"Fail",
    "row_error_object_array":[{"data1":"val1","data2":"val2","data3":"val3","data4":"val4","data5":["array"]}],
    "overall_error_array":[]
}

根据成功或失败,错误数组可能有值,也可能没有值。
到目前为止,我已经能够将这种格式从我的PHP返回到ExtJS框架中。我能够通过执行以下操作来获取非数组值,success和message:

failure: function (form, action) {

    console.log('fail hit!');

    var data = Ext.JSON.decode(action.response.responseText);

    console.log('action is = ' + action);

    var success_ = data.success;
    var message_ = data.message;
    var row_error_ = data.row_error_object_array;
    var overall_error_ = data.overall_error_array;

    console.log('succees: ' + success_);
    console.log('message: ' + message_);
    console.log('row_error: ' + row_error_);
    console.log('overall_error: ' + overall_error_);

    var row_error_object = Ext.JSON.decode(row_error_);
    var overall_error_object = Ext.JSON.decode(overall_error_);

    console.log('row_error_object: ' + row_error_object);
    console.log('overall_error_object: ' + overall_error_object);

    if(row_error_.length > 0){
        console.log('row error present!!');
        console.log('row error data1 = ' + row_error_.data1);
        console.log('row error data2 = ' + row_error_.data2);
        console.log('row error data3 = ' + row_error_.data3);
        console.log('row error data4 = ' + row_error_.data4);
        console.log('row error data5 = ' + row_error_.data5);
    }

},

在本例中,由于错误数组为空,因此对成功情况不感兴趣。
但是,日志显示以下内容:

row_error: [object Object]
row error data1 = undefined
row error data2 = undefined
row error data3 = undefined
row error data4 = undefined
row error data5 = undefined

不知道我在这里做错了什么,ExtJS知道它们是一个对象,但是当我尝试使用object.property技巧时,它显示我未定义。
我如何从服务器反序列化嵌套的JSON响应?或者有什么好的解决方法吗?

6bc51xsx

6bc51xsx1#

一个JSON.decode就足够了。你试着使用row_error_array类对象--这是错误的。你可以得到数组中第一个元素的data键:

console.log('row error data1 = ' + row_error_[0].data1);

小提琴

相关问题