0

我有一家商店如下。

var eventsStore = new Ext.data.Store({
    model: 'Event',
    sorters: [{
        property: 'OccurringOn',
        direction: 'DESC'
    }],
    proxy: {
        type: 'ajax',
        url: BaseURL + 'Events.php',
        api: {
            read: BaseURL + 'Events.php',
            create: BaseURL + 'Events.php'
        },
        reader: {
            type: 'xml',
            root: 'Events',
            record: 'Event'
        },
        writer: {
            type: 'xml',
            writeAllFields: false,
            root: 'Events',
            record: 'Event'
        }
    },
    getGroupString: function(record) {
        if (record && record.data.OccurringOn) {
            console.log(record.get('OccurringOn'));
            return record.get('OccurringOn').toDateString();
        }
        else {
            return '';
        }
    }
});

我还有一个列表视图,它可以让所有事件都正常。我有一个允许用户添加新事件的表单,并且我有 FormPanel。FormPanel 具有工具栏,该工具栏具有保存按钮,单击该按钮将执行以下操作。

var eventCard = It's a card

var newEventCard = eventCard.items.items[1];

var currentEvent = newEventCard.getRecord();

newEventCard.updateRecord(currentEvent);

var errors = currentEvent.validate();

// here I check errors and prompt user about them

var eventList = eventCard.items.items[0].items.items[0];
var eventStore = eventList.getStore();

eventStore.add(currentEvent);
eventStore.sync();
eventStore.sort( [ { property: 'OccurringOn', direction: 'DESC' } ] );
eventList.refresh();

上面的代码向 MySQL 数据库添加了两个空行,并复制了带有 3 个空的新项目的事件列表视图项目。为什么这是行为以及我所缺少的?

如果您能告诉我同步时将哪些参数作为 POST 发送到 Events.php,那将不胜感激。

4

1 回答 1

1

我发现是我的错。当有对服务的 POST 请求时,我正在回应。

于 2011-10-09T18:51:26.717 回答