Foros del Web » Programando para Internet » Javascript » Frameworks JS »

sobre las buenas prácticas

Estas en el tema de sobre las buenas prácticas en el foro de Frameworks JS en Foros del Web. Buenas, llevo ya bastantes linias programadas y me he dado cuenta que lo que empezaban siendo 4 controles tontos ha terminado en muchiiiisimas lineas de ...
  #1 (permalink)  
Antiguo 01/09/2010, 10:04
FDA
 
Fecha de Ingreso: agosto-2010
Mensajes: 99
Antigüedad: 14 años, 5 meses
Puntos: 2
sobre las buenas prácticas

Buenas, llevo ya bastantes linias programadas y me he dado cuenta que lo que empezaban siendo 4 controles tontos ha terminado en muchiiiisimas lineas de codigo dentro del $document(ready).

No me refiero a funciones tipo validación de un formulario, que las llamo a un archivo js externo de toda la vida, sino al manejo de eventos tipo estos por ejemplo:

Código:
$('#container-1').tabs({ remote: true });
			$('#container-2').tabs({ remote: true });
			$('#container-3').tabs({ remote: true });
			$('#container-4').tabs({ remote: true });
			
			$("#tancar_inici").click(function(event){
				$("#soccer").fadeIn();
				$("#football").fadeIn();
				$("#caixa_main").hide();
				$("#logo").animate({'top':"50%"},"slow");
				$("#logo2").animate({'top':"50%"},"slow");
			});
Estoy seguro de que hay una forma más limpia i eficiente de colocar todo eso, pero no he encontrado donde o como.

Y ya puestos a preguntar sobre buenas prácticas... Ahora estoy haciendo otra cosa, tiene muchas cajas de aspecto idéntico, pero no encuentro la manera de decirle esto:

Código:
$(".down").click(function() {
		var dtop=$("#interior_c1").css("top");
		dtop=parseInt(dtop);
		dtop=dtop+50;
		dtop=String(dtop);	
		dtop=dtop+"px";	
		$("#interior_c1").animate({'top':dtop},"slow");
	});
sin tener que especificar cada class .down (es decir sin .down1 .down2......) y lo mismo para cada #interior. Como me lo puedo manejar para que entienda que al darle a un div uno tiene que moverse pero los demas no? habia visto algo tipo .find o .child, pero no terminé de pillarlo.

Grácias!
  #2 (permalink)  
Antiguo 01/09/2010, 12:12
Avatar de mayid
Colaborador
 
Fecha de Ingreso: marzo-2009
Ubicación: BsAs
Mensajes: 4.014
Antigüedad: 15 años, 9 meses
Puntos: 101
Respuesta: sobre las buenas prácticas

Para el primer caso, en vez de seleccionar los controles por id, seleccionalos por className. Así, con una sola definición vas a poder manejar varios efectos a la vez.

Sobre lo segundo, si entiendo bien, pensá que un mismo tag html puede tener varios nombres de clase. Entonces, si vos tenes una sucesión ".down1", ".down2" etc nada impide que también tengas asignada una clase extra para manejar a todos a la vez:

<div class="down1 grupoDown">

Que responderá al selector:
$(".grupoDown")
  #3 (permalink)  
Antiguo 02/09/2010, 05:07
 
Fecha de Ingreso: diciembre-2009
Ubicación: Misiones
Mensajes: 867
Antigüedad: 15 años, 1 mes
Puntos: 65
Respuesta: sobre las buenas prácticas

también se puede seleccionar varios id

en vez de
$('#container-1').tabs({ remote: true });
$('#container-2').tabs({ remote: true });
$('#container-3').tabs({ remote: true });
$('#container-4').tabs({ remote: true });

esto
$('#container-1, #container-2, #container-3, #container-4').tabs({ remote: true });

pero mejor por clases

para acumuladores como dtop=dtop+50;
se puede hacer dtop += 50; no es gran cosa pero queda mas limpio jeje

para trabajar con el elemento que le hiciste click usas $(this)

Código HTML:
Ver original
  1. <title>Prueba</title>
  2. <script src="http://ajax.googleapis.com/ajax/libs/jquery/1.4.2/jquery.min.js"></script>
  3.    
  4. $(function (){
  5.     $('div').click( function (){
  6.         alert ( $(this).text() )
  7.     });
  8. });
  9.     div{width:30px; height:30px; background:blue; margin:10px; float:left}
  10. </head>
  11. <div>Uno</div>
  12. <div>Dos</div>
  13. <div>Tres</div>
  14. </body>
  15. </html>


otra que te podes encontrar es seleccionar un elemento y hacer una cosa, seleccionar otra vez el mismo elemento y hacer otra cosa y asi varias veces como:

$('el').append("asd");
$('el').width('200');
$('el').height('200');
$('el').prepend("ddd");

que mejor encadenar
$('el').append("asd").width('200').height('200').p repend("ddd");
  #4 (permalink)  
Antiguo 02/09/2010, 08:02
FDA
 
Fecha de Ingreso: agosto-2010
Mensajes: 99
Antigüedad: 14 años, 5 meses
Puntos: 2
Respuesta: sobre las buenas prácticas

mmm vale, he podido recortar un poco el codigo, ya veo que los eventos tengo que gestionarlos si o si desde el mismo $document(ready) así k solo me queda hacer que ocupen el minimo espacio para optimizar el tiempo.

Para lo segundo creo k no me he explicado bien.

Tengo varias cajas, cada una con su información de este estilo:
Código:
<div id="caixa_main">
		<img src="last_news.jpg" class="titol" alt="ultimas noticias" />
		<img src="fletxa_up.jpg" class="up" alt="ultimas noticias" />
		<div id="interior_c1">
			Aquí van les noticies
		</div>
		<img src="fletxa_down.jpg" class="down" alt="ultimas noticias" />
	</div>
En esta caja por ejemplo salen algunas de las ultimas noticias, y pudes hacer que suba o baje la información. Al lado va otra caja con resultados de partidos, donde también se puede subir i bajar para ver todos los resultados uno a uno.

Si lo pongo todo con el mismo id o el mismo className a la que le dé a subir a uno me subiran todos. Pero alguna forma debe haber de que detecte qué caja es la que debe mover, no?
Puedo hacerlo como hasta ahora, pero tantas y tantas lineas de codigo (y aun no he terminado) empiezan a asustarme por su peso y tiempo que tardará en cargar.

Grácias a los dos!
  #5 (permalink)  
Antiguo 02/09/2010, 08:20
Avatar de mayid
Colaborador
 
Fecha de Ingreso: marzo-2009
Ubicación: BsAs
Mensajes: 4.014
Antigüedad: 15 años, 9 meses
Puntos: 101
Respuesta: sobre las buenas prácticas

Cita:
Si lo pongo todo con el mismo id


Cita:
para trabajar con el elemento que le hiciste click usas $(this)
A partir de tener identificado el elemento en que hiciste click, podes usar selectores jerarquicos para detectar divs contenedores (ver: parent y children).

En fin, no se si entendí del todo tu último problema, pero espero que con los selectores accedas a donde necesites.
  #6 (permalink)  
Antiguo 02/09/2010, 08:35
FDA
 
Fecha de Ingreso: agosto-2010
Mensajes: 99
Antigüedad: 14 años, 5 meses
Puntos: 2
Respuesta: sobre las buenas prácticas

sisi, entendiste bien. Ahora ya sé lo que tengo que mirar y aprender, lo del parent i el children....
Lo que no tengo muy claro es si funcionará con la estructura que he hecho, ya que la imagen para subir o bajar esta dentro de la caja, pero lo que se mueve es el div interior_c1 que también está dentro de la caja.

Me pondré a hacer pruebas, k es la unica manera de entender como funcionan las cosas jejejej
  #7 (permalink)  
Antiguo 02/09/2010, 10:12
Avatar de mayid
Colaborador
 
Fecha de Ingreso: marzo-2009
Ubicación: BsAs
Mensajes: 4.014
Antigüedad: 15 años, 9 meses
Puntos: 101
Respuesta: sobre las buenas prácticas

Sería bueno que publiques tu estructura, así también la vemos ;o)
  #8 (permalink)  
Antiguo 07/09/2010, 08:19
FDA
 
Fecha de Ingreso: agosto-2010
Mensajes: 99
Antigüedad: 14 años, 5 meses
Puntos: 2
Respuesta: sobre las buenas prácticas

al final logré solucionarlo gracias a vosotros!

os pongo como dejé el codigo:
Código:
$(".down").click(function() {
		var top=$(this).siblings(".interior").css("top");
		top=parseInt(top);
		if (top>-119){	
			var dtop=$(this).siblings(".interior").css("top");
			dtop=parseInt(dtop);
			dtop=dtop-89;
			top=dtop;
			dtop=String(dtop);	
			dtop=dtop+"px";	
			$(this).siblings(".interior").animate({'top':dtop},"slow");
		}
	});
	
	$(".up").click(function() {
		var top=$(this).siblings(".interior").css("top");
		top=parseInt(top);
		if (top<59){
			var dtop=$(this).siblings(".interior").css("top");
			dtop=parseInt(dtop);
			dtop=dtop+89;
			top=dtop;
			dtop=String(dtop);	
			dtop=dtop+"px";	
			$(this).siblings(".interior").animate({'top':dtop},"slow");
		}
	});
Ahora ahí dentro puedo llamar por php a las ultimas noticias. y para que el interior dé la sensacion de desplazarse hacia arriba jugué con el z-index de los elementos que intervenian i con un overflow:hidden del div principal de la caja.

Gràcias!

Etiquetas: prácticas
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:31.