• Empleos
  • Sobre nosotros
  • profesionales
    • Inicio
    • Empleos
    • Cursos y retos
  • empresas
    • Inicio
    • Publicar vacante
    • Nuestro proceso
    • Precios
    • Evaluaciones
    • Nómina
    • Blog
    • Comercial
    • Calculadora de salario

0

155
Vistas
Cómo obtener el contenido js de la propiedad, editarlo y ejecutarlo con titiritero

Estoy tratando de usar titiritero para obtener el contenido de propiedad de un elemento, editarlo y ejecutar la versión editada. Por ejemplo: Existe este elemento:

 <a href="#" onclick="mojarra.jsfcljs(document.getElementById('j_idt58'),{'j_idt58:j_idt201:0:j_idt203':'j_idt58:j_idt201:0:j_idt203'},'_blank');return false" class="btn btn-info"></a>

Lo que necesito es obtener el contenido onclick, eliminar el parámetro _blank y ejecutar el resto de la función... ¿Alguna idea?

almost 3 years ago · Juan Pablo Isaza
1 Respuestas
Responde la pregunta

0

tal vez no sea la solución más poderosa que existe, pero si solo necesita hacer esto en esta etiqueta específica, puede configurar el atributo onclick con JavaScript dentro de page.evalauate de esta manera:

 await page.evalauate(() => { document .querySelector(".btn.btn-info") .setAttribute( "onclick", document .querySelector(".btn.btn-info") .onclick.toString() .split("\n")[1] .replace(",'_blank'", "") ); }); await page.click(".btn.btn-info");

¿Que está pasando aqui?

  1. ejecutamos JavaScript simple dentro del alcance de la página con page.evaluate
  2. seleccionamos la etiqueta con document.querySelector
  3. y establezca su atributo onclick (¡no su propiedad!)
  4. obtener el valor del nodo de onclick como cadena:
 mojarra.jsfcljs(document.getElementById('j_idt58'),{'j_idt58:j_idt201:0:j_idt203':'j_idt58:j_idt201:0:j_idt203'},'_blank');return false
  1. usando la segunda línea de la función (ya que no necesitamos la primera línea 'function onclick(event) {' cuando la reasignamos como el atributo)
  2. y reemplazando el parámetro ,'_blank' de la función original (cadena).
  3. el resultado será:
 mojarra.jsfcljs(document.getElementById('j_idt58'),{'j_idt58:j_idt201:0:j_idt203':'j_idt58:j_idt201:0:j_idt203'});return false
  1. finalmente haciendo clic en el botón con page.click ejecuta la nueva función

alternativamente, puede usar attributes.onclick.nodeValue si no se siente cómodo con toString().split("\n")[1] arriba:

 document.querySelector(".btn.btn-info").attributes.onclick.nodeValue.replace(",'_blank'", "")
almost 3 years ago · Juan Pablo Isaza Denunciar
Responde la pregunta
Encuentra empleos remotos

¡Descubre la nueva forma de encontrar empleo!

Top de empleos
Top categorías de empleo
Empresas
Publicar vacante Precios Nuestro proceso Comercial
Legal
Términos y condiciones Política de privacidad
© 2025 PeakU Inc. All Rights Reserved.

Andres GPT

Recomiéndame algunas ofertas
Necesito ayuda