我从一个小测试开始,它包含来自Grid中PostgreSQL的显示数据。 Grid Store有一个Ajax代理
以下是代码:
的模型/管理/ Client.js
Ext.define('Chronos.model.manage.Client', {
extend : 'Ext.data.Model',
fields : [
{name : 'id', type: 'int'},
{name : 'name', type: 'string'}
]
});
商品/管理/ Client.js
Ext.define('Chronos.store.manage.Clients', {
extend : 'Ext.data.Store',
model : 'Chronos.model.manage.Client',
sorters : ['name'],
autoLoad : false,
autosync : true,
storeId : 'manageClientsStore',
proxy : {
type : 'ajax', // Ext.data.proxy.Ajax
api : {
create : 'api/management/clients.create.php',
read : 'api/management/clients.read.php',
update : 'api/management/clients.update.php',
destroy : 'api/management/clients.destroy.php'
},
reader : {
type : 'json', // Ext.data.reader.Json
rootProperty : 'records'
},
writer : {
type : 'json', // Ext.data.writer.Json
encode : true
}
}
});
查看/管理/ Client.js
Ext.define('Chronos.view.manage.Clients', {
extend : 'Ext.window.Window',
requires : [
'Chronos.view.manage.ClientsController',
'Chronos.model.manage.Client',
'Chronos.store.manage.Clients'
],
controller : 'manageclients',
modal : true,
layout : {
type : 'vbox',
align : 'stretch'
},
width : 300,
height : 500,
title : 'Kunden Verwaltung',
items: [{ // Grid
xtype : 'grid',
store : 'manage.Clients',
flex : 1,
selType : 'cellmodel',
plugins : 'cellediting',
dockedItems: [{
xtype: 'toolbar',
items: [{
xtype : 'button',
icon : 'resources/icons.32/kunden.neu.png',
text : 'Neuer Kunde',
scale : 'large',
handler : 'onClientAdd'
}, {
xtype : 'button',
icon : 'resources/icons.32/kunden.löschen.png',
text : 'Kunde löschen',
scale : 'large',
handler : 'onClientDelete',
disabled : true
}]
}],
columns: [{
text: 'id',
dataIndex: 'id',
align: 'right',
width: 50,
hidden: true
}, {
text: 'Name',
dataIndex: 'name',
flex : 1,
editor: {
xtype : 'textfield',
allowBlank: false
}
}],
listeners: {
render: {
scope: this,
fn: function(grid) {
grid.getStore().load();
}
}
}
}]
});
商店只会加载渲染,就像我想要的那样 它可以很好地显示数据,但不能写回来。调用Create,Update或Distroy url(我知道,因为我在php代码中写了一个文件)。
我忘记了什么?
由于
答案 0 :(得分:1)
一切都很好,但autoSync
Ext.define('Chronos.store.manage.Clients', {
...
autoSync : true,
抱歉