Как добавить записи в json-store
var store = new Ext.data.JsonStore({
id:'jfields',
totalProperty:'totalcount',
root:'rows',
url: 'data.php',
fields:[{ name:'jfields' },
{ name:'firstyear' , mapping :'firstyear' , type:'float' },
{ name:'secondyear', mapping :'secondyear', type:'float' },
{ name:'thirdyear' , mapping :'thirdyear' , type:'float' },
{ name:'fourthyear', mapping :'fourthyear', type:'float' },
{ name:'fifthyear' , mapping :'fifthyear' , type:'float' } ]
}
});
Я хочу добавить данные в конец для этого магазина, но я полностью смущен, что я сделал, это добавить к нему следующий код, но не работает.
listeners: {
load : function(){
BG_store.add([{"jfields":"Monthly","firstyear":22.99,"secondyear":21.88,"thirdyear":21.88,"fourthyear":22.99,"fifthyear":21.88}]);
}
}
Но я не думаю, что моя концепция очищена, пожалуйста, любой орган показывает, как это сделать.
Ответы
Ответ 1
Вам нужно определить тип записи, создать ее и на ней, например:
TaskLocation = Ext.data.Record.create([
{name: "id", type: "string"},
{name: "type", type: "string"},
{name: "type_data", type: "string"},
{name: "display_value", type: "string"}
]);
Тогда:
var record = new TaskLocation({
id: Ext.id(),
type: "city",
type_data: "",
display_value: "Brighton"
});
Тогда:
my_store.add(record);
my_store.commitChanges();
Помните, что время, когда данные находятся в хранилище, не находится в том же формате, что и вы его отправили, но в объектах записи.
Ответ 2
См. свойство recordType
в JsonStore. Это функция, которая может использоваться как конструктор записи для рассматриваемого хранилища. Используйте его так:
var newRecord = new myStore.recordType(recordData, recordId);
myStore.add(newRecord);
Ответ 3
Я также нашел простое решение для этого:
listeners: {
load: function( xstore , record , option ) {
var u = new xstore.recordType({ jfields : 'monthly' });
xstore.insert(record.length, u);
}
}
Здесь то, что я должен добавить, это прослушиватели, так как при загрузке данных он будет создавать тип записи, а вы можете добавлять поля как данные так же, как и хотите