Foros del Web » Programando para Internet » Javascript »

Extender elementos de formulario

Estas en el tema de Extender elementos de formulario en el foro de Javascript en Foros del Web. Hola a todos, espero que algún Gurú en JavaScript pueda darme al menos una pista de como implementar esto: Me gustaría extender solo los elementos ...
  #1 (permalink)  
Antiguo 06/10/2011, 10:24
Avatar de Artificium  
Fecha de Ingreso: enero-2011
Mensajes: 492
Antigüedad: 13 años, 11 meses
Puntos: 81
Extender elementos de formulario

Hola a todos, espero que algún Gurú en JavaScript pueda darme al menos una pista de como implementar esto: Me gustaría extender solo los elementos de formulario, no importa si puedo extenderlos uno por uno, solo quiero saber si puedo agregar un método a todos los inputs, select button, textarea, etc., dentro de mi proyecto. Gracias de antemano a todos. Y si alguien sabe que definitivamente no se puede también le agradecería que me lo dijera.

Última edición por Artificium; 06/10/2011 a las 10:58
  #2 (permalink)  
Antiguo 06/10/2011, 11:11
Avatar de ArturoGallegos
Moderador
 
Fecha de Ingreso: febrero-2008
Ubicación: Morelia, México
Mensajes: 6.774
Antigüedad: 16 años, 9 meses
Puntos: 1146
Respuesta: Extender elementos de formulario

no me queda claro tu concepto de extender ñ.ñ a mi entender te refieres a que cambien el ancho ?¿ ando bien o estoy perdido?

si es eso puedes utilizar el evento onclik o focus para asignarles otro tamaño, o incluso con puro CSS

Código CSS:
Ver original
  1. input[type="text"]:focus{widt:300px;}
  #3 (permalink)  
Antiguo 06/10/2011, 11:29
Avatar de Artificium  
Fecha de Ingreso: enero-2011
Mensajes: 492
Antigüedad: 13 años, 11 meses
Puntos: 81
Respuesta: Extender elementos de formulario

Definitivamente estás perdido, estoy hablando de programacion orientada a objetos en JavaScript, gracias de todos modos por intentar ayudarme. Saludos!

Última edición por Artificium; 06/10/2011 a las 11:35
  #4 (permalink)  
Antiguo 06/10/2011, 12:29
Avatar de h2swider  
Fecha de Ingreso: julio-2007
Ubicación: Ciudad de Buenos Aires
Mensajes: 932
Antigüedad: 17 años, 4 meses
Puntos: 194
Respuesta: Extender elementos de formulario

No es posibles extender nativos en JS. :)
__________________
Codifica siempre como si la persona que finalmente mantedra tu código sea un psicópata violento que sabe donde vives
  #5 (permalink)  
Antiguo 07/10/2011, 15:14
Avatar de Artificium  
Fecha de Ingreso: enero-2011
Mensajes: 492
Antigüedad: 13 años, 11 meses
Puntos: 81
Respuesta: Extender elementos de formulario

Ya me parecía que no era posible hacer lo que quería, pero en cuanto a los que dice h2swider, claro que se puede extender nativos, se puede extender String y otros objetos predefinidos, pero extender inputs, selects, textareas, etc. creo que no es posible (y seguramente tampoco otros objetos más). De todas maneras ya ideé la forma de resolver mi problema. Gracias de todas maneras h2swider por responder.

Última edición por Artificium; 07/10/2011 a las 21:16
  #6 (permalink)  
Antiguo 08/10/2011, 11:04
Avatar de Panino5001
Me alejo de Omelas
 
Fecha de Ingreso: mayo-2004
Ubicación: -34.637167,-58.462984
Mensajes: 5.148
Antigüedad: 20 años, 6 meses
Puntos: 834
Respuesta: Extender elementos de formulario

Cita:
Iniciado por h2swider Ver Mensaje
No es posibles extender nativos en JS. :)
Sí y no. Depende. Primera aclaración: los objetos que supuestamente no se pueden extender son los objetos host (document, window, frames. etc). Los objetos nativos (Date, Math, etc) pueden extenderse modificando su prototipo (prototype) sin problemas si uno sabe lo que hace.
Los objetos host pueden extenderse de varias maneras, algunas más correctas que otras. Algunos navegadores permiten modificar su prototipo, para otros ni siquiera tienen prototipo (y ambas posturas son correctas de acuerdo al estandar, ya que no es necesario que respondan a las características de los objetos tradicionales javascript).
Una manera un tanto incorrecta de extender objetos host sería esta:
Código PHP:
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<
html xmlns="http://www.w3.org/1999/xhtml">
<
head>
<
meta http-equiv="Content-Type" content="text/html; charset=UTF-8" />
<
title>Untitled Document</title>
<
script type="text/javascript">

var 
ej=(
    function(){
        var 
mp={
            
addEvent: function(typefn ) {
            if ( 
this.addEventListener ) {
                
this.addEventListenertypefnfalse );
            } else if(
this.attachEvent){
                var 
_this=this;
                var 
f= function(){fn.call(_this,window.event);}
                
this.attachEvent'on'+typef);
            }else{
                throw new 
Error('Estás navegando en una balsa agujereada: es hora de cambiar de navegador!');
            }
            return 
this;
            },
            
customFocus:function(){
                
this.style.background='pink';
                return 
this;
            },
            
customBlur:function(){
                
this.style.background='white';
                return 
this;
            },
            
extendido:1
            
        
};
        return {
            
extend:function(el,obj){
                if(
el.extendido && el!=mp)return el;
                for(var 
i in obj)
                    
el[i]=obj[i];
                return 
el;
            },
            
get:function(id){
                if(!
document.getElementById(id))return false;
                return 
ej.extend(document.getElementById(id),mp);
            },
            
geto:function(obj){
                return 
ej.extend(obj,mp);
            }
        };
    }    
)();
var $=
ej.get,_$=ej.geto;
_$(window).addEvent('load',function(){$('pp').addEvent('focus',function(){this.customFocus();}).addEvent('blur',function(){this.customBlur();});});
</script>
</head>

<body>
<form action="" method="get">
<input id="pp" name="" type="text" />
</form>
</body>
</html> 
Es un tanto incorrecta porque agrega métodos y propiedades a objetos host aprovechando que se comportan como un objeto javascript Object, pero el problema es que aunque ahora funciona en todos los navegadores, esto puede cambiar en el futuro y además puede ocasionar cconflictos y problemas de rendimiento si no se sabe muy bien lo que se hace. No obstante esto, Frameworks conocidos utilizan esta técnica.

Una mejor aproximación es usar un wrapper: envolver el objeto host en otro. Ese objeto envoltorio es el que tiene las propiedades y métodos que extienden de manera indirecta las propiedades del objeto host. Pero la ventaja es que nunca se agrega nada al objeto host: el que hace todo el trabajo es el wrapper:
Código PHP:
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<
html xmlns="http://www.w3.org/1999/xhtml">
<
head>
<
meta http-equiv="Content-Type" content="text/html; charset=UTF-8" />
<
title>Untitled Document</title>
<
script type="text/javascript">

var 
ej=(
    function(){
        var 
extendidos={};
        var 
mp={
            
addEvent: function(typefn ) {
                var 
_this=this;
                if ( 
this[0].addEventListener ) {
                    var 
f= function(){fn.call(_this);};
                    
this[0].addEventListenertypeffalse );
                } else if(
this[0].attachEvent){
                    var 
f= function(){fn.call(_this,window.event);};
                    
this[0].attachEvent'on'+typef);
                }else{
                    throw new 
Error('Estás navegando en una balsa agujereada: es hora de cambiar de navegador!');
                }
                return 
this;
            },
            
customFocus:function(){
                
this[0].style.background='pink';
                return 
this;
            },
            
customBlur:function(){
                
this[0].style.background='white';
                return 
this;
            }
            
        };
        return {
            
extend:function(el,obj){
                if(
el[0]!==document && el!==mp){
                    
el[0].id=el[0].id || '____'+(+new Date())+Math.random();
                }
                if( 
el!==mp && extendidos.hasOwnProperty(el[0].id || 'document'))
                    return 
extendidos[(el[0].id || 'document')];    
                for(var 
i in obj)
                    
el[i]=obj[i];
                if(
el!==mp)
                    
extendidos[(el[0].id || 'document')]=el;
                return 
el;
            },
            
get:function(id){
                if(!
document.getElementById(id))
                    return 
false;
                var 
el=[];
                
el[0]=document.getElementById(id);
                return 
ej.extend(el,mp);
            },
            
geto:function(obj){
                var 
el=[];
                
el[0]=obj;
                return 
ej.extend(el,mp);
            }
        };
    }    
)();
var $=
ej.get,_$=ej.geto;
_$(window).addEvent('load',function(){$('pp').addEvent('focus',function(){this.customFocus();}).addEvent('blur',function(){this.customBlur();});});
</script>
</head>

<body>
<form action="" method="get">
<input id="pp" name="" type="text" />
</form>
</body>
</html> 
Son sólo ejemplos. Hay que agregar varias optimizaciones para poder usarlos en un ambiente real.
  #7 (permalink)  
Antiguo 08/10/2011, 11:15
Avatar de Artificium  
Fecha de Ingreso: enero-2011
Mensajes: 492
Antigüedad: 13 años, 11 meses
Puntos: 81
Respuesta: Extender elementos de formulario

Gracias por tu respuesta, aunque ya había pensado en algo parecido.

Etiquetas: elementos, extender, formulario
Atención: Estás leyendo un tema que no tiene actividad desde hace más de 6 MESES, te recomendamos abrir un Nuevo tema en lugar de responder al actual.
Respuesta




La zona horaria es GMT -6. Ahora son las 05:52.