Skip to main content

Eliminando el binding en Visual Web

Uno de los aspectos mas controversiales con Visual Web y los componentes woodstoock, ha sido el binding de los componentes. Ligado desde las versiones previas de Java Studio Creator, esta caracteristica un poco criticada, era causante de algunos consumos adicionales de memoria en el diseñador visual adicionalmente, obligaba a ligar cada componente. Utilizado por muchos desarrolladores, pero la mayoria de usuarios de la herramienta no era algo importante, en la version 6.1 beta esta caracteristica se ha omitido Sand Chitale, nos muestra en su blog, la forma de eliminarlo en proyectos anteriores.

Codigo generado en las versiones previas


Codigo en la nueva versión



resumiendo , ya no se generara codigo como este para cada componente
private HtmlPanelGrid gridPanel1 = new HtmlPanelGrid();

public HtmlPanelGrid getGridPanel1() {
return gridPanel1;
}

public void setGridPanel1(HtmlPanelGrid hpg) {
this.gridPanel1 = hpg;
}

Entre algunas ventajas, notaras un IDE más rapido en la construcción de aplicaciones Visual Web, y una mejor generación de codigo.

Algo que aun falta mejorar bastante es el presentación visual del faces-config.xml, con unas cuantas paginas se ve muy bien, pero en grandes proyectos la represantación de componentes es un poco complicada de visualizar de manera sencilla. Siempre es mejor editar directamente el XML, para definir las reglas de navegación.


Tambien nos permite ordenarlo un poco de manera que da un mejor seguimiento.

Comments

Popular posts from this blog

Apache NetBeans

Apache NetBeans
https://wiki.apache.org/incubator/NetBeansProposal

Si, algo que se esperaba desde hace muchos años, una liberación de NetBeans, para convertirlo en un IDE más abierto, y que permita mayor contribución de la comunidad y de otras empresas, ya inicio su primera etapa en la incubadora de la Fundación Apache.
Las implicaciones que esto conlleva son múltiples por una parte esta la evolución de NetBeans, al permitir que más contribuyentes puedan aportar a sus mejoras, también garantiza que aquellas instituciones no sientan que es una sola organización la que controla la evolución. A las comunidades les permite sentirse que participan de un proyecto con todas las garantías que ofrece la Fundación Apache.

Muchos pensaran que Oracle esta dejando morir el proyecto, la realidad es diferente, hay muchos ingenieros que están participando del proyecto en la fundación Apache.
Es una noticia excelente para los desarrolladores, instituciones, empresas que utilizan NetBeans , se estima qu…

Un ejemplo sencillo de Refactorización y Genericos

Un ejemplo sencillo de Refactorización y Genericos

public class Refactorizador<K, V> {

    public V copyFromBeans(K k, V v) {
        try {
            Class claseK = k.getClass();
            Class claseV = v.getClass();

            Method[] metodosK = claseK.getMethods();

            for (Method method : metodosK) {
                if (isGetter(method)) {
                    Method metodoGetK = claseK.getDeclaredMethod(method.getName());
                    Method metodoSetV = claseV.getDeclaredMethod(changeGetBySet(method.getName()), method.getReturnType());
                    metodoSetV.invoke(v, metodoGetK.invoke(k));
                }

            }

        } catch (Exception e) {
            System.out.println("refactorizador() " + e.getLocalizedMessage());
        }
        return v;
    }

     public  boolean isGetter(Method method) {

        if (!method.getName().startsWith("get")) {
            return false;
        }
        if (method.getName().startsWith("getCla…

FileUpload con Primefaces

FileUpload con Primefaces

Si queremos subir imagenes a nuestra aplicación usaremos el componente FileUpload Debemos realizar los siguientes pasos:
Agregar al archivo web.xml

   <filter>        <filter-name>PrimeFaces FileUpload Filter</filter-name>        <filter-class>            org.primefaces.webapp.filter.FileUploadFilter        </filter-class>    </filter>    <filter-mapping>        <filter-name>PrimeFaces FileUpload Filter</filter-name>        <servlet-name>Faces Servlet</servlet-name>    </filter-mapping>



Crear dentro de resources el directorio donde deseamos almacenar las imagenes En este ejemplo: resources/fotos/clinicas y agregue una imagen llamada fotos.png que se usará como imagen inicial.



En JSFUtil u otro @Named Beans que usemos agregamos tres métodos uno para obtener el path de la aplicación web , otro para obtener el path relativo a /fotos/clinicas y el otro para copiar los archivos. /*