Sencha Touch FormPanel与商店

时间:2011-09-28 10:46:10

标签: sencha-touch store formpanel

我的商店如下。

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会非常感激。

1 个答案:

答案 0 :(得分:1)

我想通了,这是我的错。当有POST请求时,我正在回应。