Вопрос

Я новичок в Extjs 4 и пытаюсь реализовать простое приложение в стиле MVC. Документация действительно хороша, и это одна из тем, представленных в руководстве по пакетам форм, но, похоже, не работает в моем случае.

Приложение в основном может создавать, редактировать и удалять статьи. Создание и редактирование находятся в всплывающих окнах. Всплывающее окно содержит форму с текстовым полем и HTML-редактором. Пожалуйста, нажмите на ссылку ниже, это ошибка в консоли Google Chrome, когда я нажимаю кнопку «Отправить» в «Окно»

http://www.freeimagehosting.net/mjig7

Вот код, который я написал модель:

Ext.define('AM.model.Article', {
    extend: 'Ext.data.Model',
    fields: ['name', 'data'],
    proxy: {
        type: 'rest',
        url: 'users/data',
        reader: {
            type: 'json',
            root: 'myJaxBean',
            successProperty: 'success'
        },
        writer: {
            type: 'json'
        }
    }
});

Вид:

Ext.define('AM.view.New', {
    extend: 'Ext.window.Window',
    alias : 'widget.new',
    title : 'New Article',
    autoShow: true,
    fieldDefaults: {
        labelAlign: 'top',
        msgTarget: 'side'
    },
    layout: 'fit',
    bodyStyle:'padding:5px 5px 0',
    width: '70%',
    height: '40%',
    initComponent: function() {
        this.items = [
            {
                xtype: 'form',
                anchor: '99%',
                items: [
                    {
                        xtype: 'textfield',
                        name : 'name',
                        fieldLabel: 'Article Name',
                        anchor: '99%'
                    },
                    {
                        xtype: 'htmleditor',
                        name : 'data',
                        fieldLabel: 'Article',
                        anchor: '99% -25'
                    }
                ],
                buttons: [
                {
                    text: 'Submit',
                    handler: function() {
                        var form = this.up('form').getForm(), // get the basic form
                            record = form.getRecord(); // get the underlying model instance
                        if (form.isValid()) { // make sure the form contains valid data before submitting
                            form.updateRecord(record); // update the record with the form data
                            record.save({ // save the record to the server
                                success: function(user) {
                                    Ext.Msg.alert('Success', 'User saved successfully.')
                                },
                                failure: function(user) {
                                    Ext.Msg.alert('Failure', 'Failed to save user.')
                                }
                            });
                        } else { // display error alert if the data is invalid
                            Ext.Msg.alert('Invalid Data', 'Please correct form errors.')
                        }
                    }
                },
                {
                    text: 'Cancel',
                    scope: this,
                    handler: this.close
                }
            ]
            }
        ],


        this.callParent(arguments);
    }
});

и, наконец, код в моем контроллере, который делает окно видимым

Контроллер:

.....

'viewport > panel > panel > tbar button[action=newarticle]' :{
                click: this.newArticle
            },
....

   newArticle: function(button){
        var view = Ext.widget('new');
    },

Пожалуйста, укажите мне правильное направление, если я делаю что -то не так. Заранее спасибо.

Это было полезно?

Решение

Проверьте документы getRecord ():

Возвращает последний экземпляр Ext.Data.Model, который был загружен через LoadRecord

Поэтому ясно, что вы не загружаете никаких записей, поэтому вы GetRecord () возвращается неопределенным. И вы получаете свою ошибку дальше.

Лицензировано под: CC-BY-SA с атрибуция
Не связан с StackOverflow
scroll top