• Jobs
  • About Us
  • professionals
    • Home
    • Jobs
    • Courses and challenges
    • Questions
    • Teachers
  • business
    • Home
    • Post vacancy
    • Our process
    • Pricing
    • Assessments
    • Payroll
    • Blog
    • Sales
    • Salary Calculator

0

147
Views
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?

over 2 years ago · Juan Pablo Isaza
1 answers
Answer question

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'", "")
over 2 years ago · Juan Pablo Isaza Report
Answer question
Find remote jobs

Discover the new way to find a job!

Top jobs
Top job categories
Business
Post vacancy Pricing Our process Sales
Legal
Terms and conditions Privacy policy
© 2025 PeakU Inc. All Rights Reserved.

Andres GPT

Recommend me some offers
I have an error