Я использую 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
, который я не получаю, я не могу пройти.
Любая помощь приветствуется.