我有EnhancedGrid,它根据我对数据库的查询从AJAX调用获得响应后加载数据。
当我发出第一个请求时,我可以正确地看到要在网格中填充的数据。但是,我更改了我的查询,它仍然加载以前的数据。我的响应在JSON中从数据库返回正确的数据。
我尝试了所有可能的方法并使用firebug调试但无法获得输出。我尝试搜索类似的帖子,但它仍然不适合我。任何帮助将不胜感激。
我在下面粘贴我的代码。
_initialiseGrid:function(){
var layout = [
{'name': 'Project Name', 'field': 'projectName', 'width': '200px'},
{'name': 'Date Created', 'field': 'createdDate', 'width': '100px',formatter:this.formatDate},
{'name': 'Comments', 'field': 'senderComments', 'width': '250px',editable:true}
];
dataGrid = new dojox.grid.EnhancedGrid({
id: 'JoinProjectGrid',
structure: layout,
rowSelector: '20px',
plugins: {indirectSelection: {headerSelector:true}}},
document.createElement('div'));
}
_loadData:function(response){
var projectList=response.retrievedList;
var rowData = {
identifier: "projectId",
items: projectList
};
dataStore = new dojo.data.ItemFileWriteStore({data: rowData});
dataGrid.set("store",dataStore);
dojo.byId("gridDivForJoin").appendChild(dataGrid.domNode);
dataGrid.startup();
}
我尝试使用:
dataGrid.setStore(dataStore)
这不适用于第二个请求,所以, 我使用了dataGrid.set(“store”,dataStore),它没有加载新数据但显示了前一个数据。我也尝试过:
clearOnClose:true, urlPreventCache:true
刷新网格并使用下面的代码也在第二次请求时清除商店。
var newStore = new dojo.data.ItemFileReadStore({data: { identifier: "", items: []}});
dataGrid.setStore(newStore);
答案 0 :(得分:0)
我在添加
后得到了它dataGrid.render()