I have a static html form layout where i add extjs form fields using the “renderTo” config. In order to have form validation and simple submit methods i want to add the fields to a form panel. As the layout is managed by the html frame i don’t want the form to be rendered by the panel (panel has html frame as contentEl and this should be used as is).
In extjs3 i could achieve this by adding the field not to the panel but to the BasicForm (formpanel.getForm().add(…)) but in extjs4 this method seems to be gone.
How can i do this using extjs4?
Thanks in advance.
Since you already have a Panel that uses the contentEl to render HTML into its body, I recommend to stick with this approach:
Replace the panel with an Ext.form.Panel instance – the configuration, particularly the contentEl config – can remain unchanged.
The code provided here will override a standard Ext class (Ext.layout.Layout) and introduce support for a ‘renderItemTo’ config property on child items of any Ext container or panel instance (including Ext.form.Panel).
The value of the config property should be the ID of an already rendered DOM node, e.g. a DIV element that is part of the HTML fragment used in as the contentEl of the parent container’s body.
Usage:
I uploaded a working example to JSFiddle (note: resize the window if you experience a render problem – this is related to JSFiddle, not my override).