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

[SOLUCIONADO] JS deja de funcionar despues de llamada AJAX. Casi solucionado, pero...

Estas en el tema de JS deja de funcionar despues de llamada AJAX. Casi solucionado, pero... en el foro de Frameworks JS en Foros del Web. Hola, PUes eso, no consigo dar exactamente con la clave para que me siga funcionando un codigo JS despues de una llamada AJAX. He buscando ...
  #1 (permalink)  
Antiguo 03/02/2014, 13:30
 
Fecha de Ingreso: julio-2010
Mensajes: 134
Antigüedad: 14 años, 6 meses
Puntos: 0
JS deja de funcionar despues de llamada AJAX. Casi solucionado, pero...

Hola,

PUes eso, no consigo dar exactamente con la clave para que me siga funcionando un codigo JS despues de una llamada AJAX.
He buscando en el foro, y hay varias respuesta.
Lo tipico es que hay que volver a cargar el codigo JS para el nuevo contenido AJAX.

Vale... pero mi problema es el siguiente.
Lo que he hecho es crear una funcion JS con el codigo que tiene que tener el javascript, y esta funcion es llamada cada vez que se pulsa en uno te los botones que hace la llamada ajax.

El problema es que hay 7-8 botones, y no me gustaria tener que editar todo el codigo html de esos botonces para meterle el onlick-> llamada a la funcion JS.
Lo veo un poco chapucero... EDITO: Lo he probado y ni si quiera funciona. no se que ocurre, pero no funciona. parece ser que si intento volver a cargar el cod Js a la vez que la llamada no se hace bien. EN cambio si pruebo con un boton sin hacer una llamada ajax si funciona... pero claro esto no me soluciona nada.

¿No hay una forma para que se llame siempre que se ejecuta una funcion PHP en concreto? Esta funcion siempre es llamada cuando se pulsa uno de estos 7-8 botonces...

Me entendeis?


EDITO: Hay otra cosa que me preocupa y no entiendo.
La funcion es esta:

Código:
function calen_dina(){
window.addEvent('domready', function(){
		var myFxc = $$('.zc_month_dayblock');
		myFxc.makeResizable({
			modifiers: {x: false, y: 'height'},
			limit: {y: [50, 350]}
		});

});
}
SI le quito el windows.addevent... no funciona. ¿No deberia de dar igual?

He probado metendo codigo JS en mi php a pelo...
Lo curioso es que la primera vez que se carga la web completa lo hace bien, en cambio cuando uso ajax, aun sabiendo que se tiene que llamar a esa fucnion para hacer la solicitud ajax, ya no funciona.

¿Que esta pasando?

EDITO2: Pongo un poco mas de detalles que creo importantes. He intentado meter en la funcion PHP que se ejecuta con cada llamada ajax lo siguiente:
Código:
$document = JFactory::getDocument();
			$jsmario = <<< EOD
	function calen_dina(){
window.addEvent('domready', function(){
		var myFxc = $$('.zc_month_dayblock');
		myFxc.makeResizable({
			modifiers: {x: false, y: 'height'},
			limit: {y: [50, 350]}
		});

});
}
EOD;
$document->addScriptDeclaration($jsmario);
	
?>
	<script>
	calen_dina();
	</script>
<?php
Decir que que estoy en Joomla, pero creo que no deberia de influir.

GRacias!

Última edición por daicon; 03/02/2014 a las 14:19
  #2 (permalink)  
Antiguo 03/02/2014, 16:25
 
Fecha de Ingreso: abril-2011
Mensajes: 1.342
Antigüedad: 13 años, 8 meses
Puntos: 344
Respuesta: JS deja de funcionar despues de llamada AJAX. Casi solucionado, pero...

Buenas,

Por lo que veo utilizas Mootools.

Lo 1º:

Código Javascript:
Ver original
  1. function calen_dina(){
  2. window.addEvent('domready', function(){
  3.         var myFxc = $$('.zc_month_dayblock');
  4.         myFxc.makeResizable({
  5.             modifiers: {x: false, y: 'height'},
  6.             limit: {y: [50, 350]}
  7.         });
  8.  
  9. });
  10. }

Es necesario el window.addEvent('domready', .... porque aquí le estás indicando que este código se ejecute cuando el DOM este cargado (supongo que sabes lo que es el DOM y sino míralo en Google). Si no pones el código dentro de este evento se ejecutaría antes de que los elementos del DOM estén cargados y por tanto no funcionarían.

2º: Para hacer que funcione con elementos cargados dinámicamente (AJAX) tienes que volver a llamar al código anterior, pero sin el addEvent. ¿Por qué, te preguntarás? En este caso ya no tienes que esperar a que se cargue el DOM (ya está cargado). Es importante en este caso, ejecutar la función sólo para los nuevos elementos (esto dependerá de como cargues el contenido).

Un ejemplo (suponiendo que los nuevos elementos han sido cargados dentro del divCargado):

Código Javascript:
Ver original
  1. var myFxc =
  2. $("divCargado").getElements(".zc_month_dayblock");
  3.         myFxc.makeResizable({
  4.             modifiers: {x: false, y: 'height'},
  5.             limit: {y: [50, 350]}
  6.         });

Sobre los botones, lo mejor sería que tuviesen una clase común y añadir un evento click a todos ellos a la vez con el código correspondiente, pero eso depende de como tengas el código (habría que ver más código para conocer exactamente lo que se puede hacer)

Un saludo
  #3 (permalink)  
Antiguo 03/02/2014, 17:18
 
Fecha de Ingreso: julio-2010
Mensajes: 134
Antigüedad: 14 años, 6 meses
Puntos: 0
Respuesta: JS deja de funcionar despues de llamada AJAX. Casi solucionado, pero...

Cita:
Iniciado por alexg88 Ver Mensaje
Buenas,

Por lo que veo utilizas Mootools.

Lo 1º:

Código Javascript:
Ver original
  1. function calen_dina(){
  2. window.addEvent('domready', function(){
  3.         var myFxc = $$('.zc_month_dayblock');
  4.         myFxc.makeResizable({
  5.             modifiers: {x: false, y: 'height'},
  6.             limit: {y: [50, 350]}
  7.         });
  8.  
  9. });
  10. }

Es necesario el window.addEvent('domready', .... porque aquí le estás indicando que este código se ejecute cuando el DOM este cargado (supongo que sabes lo que es el DOM y sino míralo en Google). Si no pones el código dentro de este evento se ejecutaría antes de que los elementos del DOM estén cargados y por tanto no funcionarían.

2º: Para hacer que funcione con elementos cargados dinámicamente (AJAX) tienes que volver a llamar al código anterior, pero sin el addEvent. ¿Por qué, te preguntarás? En este caso ya no tienes que esperar a que se cargue el DOM (ya está cargado). Es importante en este caso, ejecutar la función sólo para los nuevos elementos (esto dependerá de como cargues el contenido).

Un ejemplo (suponiendo que los nuevos elementos han sido cargados dentro del divCargado):

Código Javascript:
Ver original
  1. var myFxc =
  2. $("divCargado").getElements(".zc_month_dayblock");
  3.         myFxc.makeResizable({
  4.             modifiers: {x: false, y: 'height'},
  5.             limit: {y: [50, 350]}
  6.         });

Sobre los botones, lo mejor sería que tuviesen una clase común y añadir un evento click a todos ellos a la vez con el código correspondiente, pero eso depende de como tengas el código (habría que ver más código para conocer exactamente lo que se puede hacer)

Un saludo

Hola, gracias!!
Ya esta solucionado!! perfecto!
He tenido que investigar un poco mas, ya que no daba con el sitio desde donde tenia que llamar a la funcion nueva, pero ya esta todo bien!

Última edición por daicon; 03/02/2014 a las 17:38

Etiquetas: ajax, funcion, funcionar, html, javascript, js, llamada, php, solucionado
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 01:37.