1

我很困惑。我有一个可编辑的 OnDemandGrid,在它下面我有一个 dstore/Rest 集合指向我的后端(在 PHP 中)。

OnDemandGrid 与编辑器混合在一起......我可以编辑我的数据,但我无法保存它。我在服务器端收到的是在集合中插入一整行的“POST”请求......而且我从未收到更新。

我不应该收到一个 PUT 请求吗?我在数据中使用id ...

这是客户端部分:

function (...)
{
        var EditGrid = declare([ OnDemandGrid, Keyboard, Editor ]);
        var coll = new Rest({
                                        target: 'my.php/x/',
                                        idProperty: 'id',
                                        rangeStartParam: 'range',
                                        rangeCountParam: 'limit',
                                        sortParam: 'sort'
                                });    
        var grid = new EditGrid({ columns: { 
                                     user_name:{
                                       label: 'User name',
                                      editor: 'text',
                                      editOn: 'click, dbclick',
                                    autoSave: true,
                                 }},
                               collection: coll }, 'grid' );
        grid.startup();
}

我正确地收到了 GET 查询来填充表格......然后,在编辑一行并点击“return”后,我得到了一个 POST!

服务器端在这里显示有点复杂......基本上,在 GET 上我执行 SQL 查询并将结果 json 化,而在 POST 上我只返回这个:

http_response_code(201);
header("location: ".$_SERVER['PATH_INFO'].$id);

$id 与我从请求中收到的 ID 相同...

POST后,我没有收到任何其他信息。在 POST 数据中,我只收到旧的、未修改的行的副本……我从来没有收到“新”的编辑数据。

在我看来,我应该在某个时候收到一个 PUT 请求……我尝试了浏览器调试器、服务器日志,但在任何地方都没有。

有人可以帮我吗?

4

1 回答 1

0

我终于修好了。

它非常令人费解,而且很少记录所有这些混乱。我不得不深入研究浏览器调试器和 dgrid/Rest 源代码。

所以问题出在我的 REST 后端。事实证明,dgrid 在 PUT/POST 请求修改项目之前执行 GET,并且它通过询问特定的“id”执行仅包含一条记录的 GET。有道理。

好吧,我的后端会以 JSON 格式返回一个包含一个元素的 ARRAY。这是错误!这没有被 dgrid 正确解析,它导致了 POST 而不是 PUT。

一旦我修复了 GET 后端以返回单个 JSON 项而不是包含一个 JSON 项的数组,dgrid 就开始发送正确的 PUT。

于 2017-11-23T08:32:26.717 回答