我正在使用带有 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 然后......