gpt4 book ai didi

javascript - Dojo - 调用排序后行从 DataGrid 中消失

转载 作者:行者123 更新时间:2023-11-30 20:52:04 25 4
gpt4 key购买 nike

我在对网格进行排序时遇到了 DataGrid 的问题。

对于这个问题,当我们在一个调用流程中执行这一系列操作时,所有行都会消失:

  1. 将一个项目添加到网格的存储中。
  2. 从网格的存储中删除一项
  3. 保存商店
  4. 调用 grid.sort。

调用 grid.sort 网格尿布中的所有行后(尽管它们仍在商店中)。如果我们重复相同的过程,它们就会回来。

我有一个复制器代码,我基于 DataGrid 的自定义网格组件在这里: MyGrid.js

如果您像我在 Scenarios.js 的第 38 行中那样调用 MyGrid 的 addOneDelOne您将能够重现该问题。

在此代码中,如果商品超过 4 件,商品将从商店中移除。

如果添加项的数量大于删除项的数量,如果我们对网格进行排序,也不会出现此问题。

我已经在 Dojo 1.9 和 1.13 上测试过了

最佳答案

我相信我们找到了解决这个问题的方法。问题出在 Dojo 的 DataGrid 的 _onFetchBegin 方法上。

当我们在 DataGrid 上调用排序时,它实际上通过调用 updateRowCount(0) 清除了一些计数器。

其中一个被清除的计数器是 this.invalidated.rowCount,DataGrid 和 dojo 实际使用它来打印记录。打印记录数等于 this.invalidated.rowCount 值。

稍后,在 grid.sort() 调用处理期间,dojo 转到 _fetch(0, isRender); 方法。此方法最终调用 this.store.fetch({...}) ,它根据从商店返回的项目更新网格。它由回调方法 _onFetchBegin 和 _onFetchComplete 完成。问题出在 _onFetchBegin

在我们的例子中,从商店返回的项目数量等于网格中的行数。 if(this.rowCount != size) <-- 这是错误的。请注意,我们在这里不使用 this.invalidated.rowCount,而是使用 this.rowCount。 this.invalidated.rowCount 之前在 updateRowCount(0) 中设置为 0。通常,当这个条件为真时,我们会调用 this.updateRowCount(size);其中 size 是商店中的商品数量。 dojo 会用行打印网格。但在我们的例子中,this.rowCountsize 是相同的(我们在记录上添加,并删除一条记录)所以我们最终在 DataGrid 中多了几行

if(!size){
this.views.render();
this._resize();
this.showMessage(this.noDataMessage);
this.focus.initFocusView();
}else{
this.showMessage(); <- we ended up here. And we we do not update the RowCount :(
}

如果我们修改 Dojo 的 DataGrid,在 this.showMessage(); 之前添加 this.updateRowCount(size);

像这样

else{
this.updateRowCount(size);
this.showMessage();
}

会好的。

关于javascript - Dojo - 调用排序后行从 DataGrid 中消失,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/48067977/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com