我正在通过 LoadRawData 将数据加载到网格面板中,但未设置总属性。
App.GP.getStore().loadRawData(obj);
最后,我重写了 LoadRawData 方法以强制它设置,但这仍然不起作用。
Ext.define('App.patch.app.Store', {
override: 'Ext.data.Store',
loadRawData: function (data, append) {
var me = this,
result = me.proxy.reader.read(data),
records = result.records;
if (result.success) {
me.totalCount = result.total;
me.loadRecords(records, { addRecords: append });
me.fireEvent('load', me, records, true);
}
}
});
我正在加载 3 条记录,页面大小为 3,但将 totalCount 设置为 8。
我逐行调试并确认 me.totalCount 设置为 8,但是当 pagegrid 加载分页工具栏中的显示消息时,显示 Offices 1 - 3 of 3。
应该是 1 - 3 of 8。
这是我的网格面板
pitem.Add(Html.X().GridPanel()
.ID("GP")
.Title(_AllOffices.SelectOffices_Text)
.Header(true)
.Border(false)
.Frame(true)
.Store(st => st.Add(Html.X().Store()
.ID("Store")
.AutoLoad(true)
.RemoteSort(false)
.IsPagingStore(true)
.RemotePaging(true)
.AutoDataBind(true)
.PageSize(3)
.Reader(x=>x.Add(Html.X().JsonReader().Root("data")))
.Model(Html.X().Model().Fields(new ModelField("Id")))
))
.ColumnModel(columnModel => columnModel.Columns.Add(Html.X().Column().Text("Id").DataIndex("Id").Flex(1)))
.SelectionModel(Html.X().CheckboxSelectionModel())
.BottomBar(bar => bar.Add(Html.X().PagingToolbar()
.DisplayInfo(true)
.HideRefresh(true)
.Listeners(x=> x.BeforeChange.Fn="GetSelectedRows").Listeners(x=> x.Change.Fn="CheckRows")
.DisplayMsg(_AllOffices.DisplayingOffices_Text + " {0} - {1} of {2}"))
)
.View(view => view.Add(Html.X().GridView()))
);
我还应该在 loadrawdata 调用之前添加我在很多列和字段中动态添加的内容,但这一切都很好。