В Extjs получите значение текстового поля, которое находится внутри настраиваемого контейнера полей.

Я использую extjs 4.1 и создал собственный контейнер полей с xtype:ptextfield, он создается путем расширения «FieldContainer», в котором есть элементы img и текстовое поле, и я хочу получить доступ к значению текстового поля из < strong>ptextfield, который является fieldcontainer.

Ext.onReady(function () {

    Ext.define('PTextField', {
        extend: 'Ext.form.FieldContainer',
        alias: 'widget.ptextfield',
        requires: ['Ext.form.TextField', 'Ext.Component'],
        alias: 'widget.ptextfield',
        height: 20,
        width: 170,
        fieldLabel: 'A',
        labelAlign: 'top',
        layout: {
            type: 'hbox'
        },
        BLANK_IMAGE_URL: '',

        initComponent: function () {
            var me = this;
            Ext.applyIf(me, {
                items: [{
                    xtype: 'component',
                    height: 20,
                    width: 20,
                    autoEl: {
                        tag: 'img',
                        src: Ext.BLANK_IMAGE_URL
                    }
                }, {
                    xtype: 'textfield',
                    itemId: 'textid',
                    width: 100
                }]
            });
            this.callParent(arguments);
        }
    });

    Ext.create('Ext.window.Window', {
        title: 'Hello',
        height: 400,
        width: 400,
        //layout: 'fit',
        items: [{
            xtype: 'ptextfield',
            fieldLabel: 'First Name',
            id: 'pcontainer1',
            listeners: {
                change: {
                    element: 'el', //bind to the underlying el property
                    fn: function () {
                        var me = this;
                        Ext.Ajax.request({
                            waitMsg: 'Saving changes...',
                            url: '/Home/SaveChanges',
                            jsonData: {
                                id: this.id,
                                value: this.down('#textid').getRawValue()
                            },
                            failure: function (response, options) {
                                Ext.MessageBox.alert('Warning', 'Oops...');
                            },
                            success: function (response, options) {
                                var text = response.responseText;
                                // process server response here
                                console.log('Changes saved successfully.');
                            }
                        });
                    }
                }
            }
        }, {
            xtype: 'ptextfield',
            fieldLabel: 'Last Name',
            id: 'pcontainer2'
        }]
    }).show();
});

В приведенной ниже строке я получаю контейнер поля "ptextfield" в "этом", а "this.id" дает мне "pcontainer1", но я не могу понять, как получить "значение" текстового поля, которое находится внутри " полеконтейнер ptextfield.

Я получаю сообщение об ошибке в следующей строке: jsonData: {id: this.id, value: this.down('#textid').getRawValue()}

Ошибка: this.down('#textid') is null (firebug) (chrome) Uncaught TypeError: невозможно вызвать метод getRawValue для null Ext.create.items.listeners.change.fn (анонимная функция) Ext.apply. createListenerWrap.wrap

где "this.down(#textid').getRawValue()" должен дать мне textfield value, который я не получаю, я не могу пройти.

Любая помощь приветствуется.


person nilesh    schedule 18.07.2012    source источник


Ответы (1)


почему вы слушаете событие изменения html-элемента контейнера? а не сказать текстовое поле?

этот способ, вероятно, проще для вас:

поместите это в поле ptext:

listeners: {
                render: function(component) {
                    component.down('textfield').on('change', function() {
                        console.log(this, arguments);
                        // "this" is the textfield
                        // do your ajax here
                    });
                }

            }
person Neil McGuigan    schedule 18.07.2012