ExtJs Grid Paging: Nächster Taste ist deaktiviert!
Frage
Ich habe ein einfaches Netz erstellt, das eine Paging -Symbolleiste hat. Aus irgendeinem Grund, wenn ich bei Index 0 lade, ist die Schaltfläche "nächste Seite" deaktiviert, obwohl in dem Text "Seite 1 von 5" angezeigt wird. Wenn ich in den Ladeparamien für den Speicher etwas höher als 0 auswähle, ermöglicht es mir, vorwärts und zurück zu pagieren, aber es wird die maximale # der Seiten nicht richtig angezeigt. Wenn ich zur ersten Seite zurückgehe, ist die nächste Schaltfläche einmal einmal wieder deaktiviert.
Irgendwelche Ideen?
function getBugGrid(activityPanelWrapper){
var pageSize = 5;
var bugStore = new Ext.data.JsonStore({
reader: new Ext.data.JsonReader({
totalProperty: 'total_count'
}),
autoLoad: {params:{start: 0, limit: pageSize}},
autoDestroy: true,
url: '/bugs/fetch',
idProperty: 'id',
region: 'center',
root: 'data',
storeId: 'bugStore',
fields: [...]
});
var columnModel = new Ext.grid.ColumnModel({
defaults: {
width: 120,
sortable: true
},
columns: [...]
});
return new Ext.grid.GridPanel({
region: 'center',
store: bugStore,
colModel: columnModel,
trackMouseOver:false,
loadMask: true,
sm: new Ext.grid.RowSelectionModel({singleSelect:true}),
listeners: {
rowclick: {
fn: function(grid, rowIndex, event) {
var bug_id = grid.store.getAt(rowIndex).id;
Ext.getCmp('activity-panel').load(activity_lines_path(bug_id));
}
}
},
bbar: new Ext.PagingToolbar({
pageSize: pageSize,
store: bugStore,
displayInfo: true,
displayMsg: 'Displaying topics {0} - {1} of {2}',
emptyMsg: "No topics to display"
})
});
}
JSON -Antwort:
{"data":[{ bug 1 },{ bug 2 },{ bug 3 },{ bug 4 },{ bug 5 }],
"errors":{},
"total_count":25}
Lösung
Sie lesen die Totalproperty im JsonReader nicht ...
Sie müssen diese Konfiguration zu Ihrem Autoload hinzufügen ...
var bugStore = new Ext.data.JsonStore({
autoDestroy: true,
url: '/bugs/fetch',
idProperty: 'id',
root: 'data',
storeId: 'bugStore',
fields: [ ... ]
autoLoad: {params:{start: 0, limit: pagesize}}
});
Sie können auch einen JSON -Leser in Ihrem JSON -Geschäft definieren:
var myStore = new Ext.data.Store({
reader: new Ext.data.JsonReader({
totalProperty: 'total_count',
...
}),
...
});