0

我正在使用带有 JsonRest 存储的 OnDemandGrid 从 RESTful API 检索数据并将其显示在表上。该表相当复杂,并且使用了所有 JsonRest CRUD 方法。这是我正在使用的基本结构:

JsonRest:

...
var restStore = Observable(Cache(JsonRest({
    target:"source", 
    idProperty: "id"
}), Memory()));
...

按需网格:

...
var grid = new (declare([OnDemandGrid, Selection, Keyboard]))({
    sort: "name",
    store: restStore,
    columns: [
           {field: "name", label: "Name"},
           {field: "state", label: "State"},
           {field: "city", label: "city"}
         ],
    loadingMessage: "Loading data...",
    noDataMessage: "No data"
}, "grid");
grid.startup();
...

我想在不发送 HTTP 请求的情况下过滤客户端的数据。你能给我一些解决这个问题的想法吗?

自己的研究:

Dgrid 教程基于这样一个事实,即一切都依赖于 dojo-store。

当 dgrid 与 store 交互时,所有的分页、过滤和排序责任都落在 store 上,而不是 grid。...遇到数据呈现问题时,请始终检查存储实现(和后端服务,如果适用)是否按预期执行。

所以这意味着我必须在商店方面解决这个问题。我想,我必须扩展 JsonRest 商店的 QueryResults 但我一直在碰壁。

我也想过查询缓存 - 但我松了 JsonRest 然后......

4

1 回答 1

0

如果您基本上对最初从您的服务中一次性检索数据有效负载感兴趣,但随后在客户端执行所有排序/过滤/分页,请查看dojo-smore/RequestMemory - 您将它传递给url它一旦从 URL 获取数据,它基本上就像一个内存存储,除了它的方法返回承诺而不是立即值。

于 2014-11-07T03:47:44.200 回答