Estoy presentando como un examen a ver mi nivel de JS y tengo varias dudas. Saqué 39/45 y mis errores son los siguientes y me gustaría que alguien me los aclarase un poco:
¿Qué se mostrará en la consola cuando "this" llama al siguiente método? (What is logged to the console as "this" when the following method was called?)
var myObj = { property : "that", whatsThis : function(that) { setTimeout(function () { console.log(this); }, 0); } } myObj.whatsThis("?");
Mi respuesta fue that
en dado caso pensé que sería myObj
pero no entiendo mucho el porqué es window
la respuesta correcta, pongo un ejemplo donde sí me salió bien:
¿Qué es "this" cuando el siguiente metodo es llamado?(What is "this" when the following method was called?)
var myObj = { property : "that", whatsThis : function(that) { return this; } } myObj.whatsThis("?");
Yo puse myObj
como respuesta y fue correcta y fue porque cuando retorno this
me refiero al objeto e ignoro el parámetro que le paso porque no hago nada pero una duda acá: ¿si pusiera return this.property
imprimiría "?" cierto? ya que le estoy cambiando el valor a la propiedad local, ¿no?
Bueno esa es mi duda la otra es
¿Por qué deberias usar prcesamiento asincrono en tu codigo JS?(Why should you make use of asynchronous processing in your JavaScript code?)
Learn more about synchronous and asynchronous requests here: https://developer.mozilla.org/en-US/docs/Web/API/XMLHttpRequest/Synchronous_and_Asynchronous_Requests
Note: There are 2 correct answers to this question.
Para acelerar las peticiones en el servidor cuando no necesitan autorizacion en el servidor - To speed up server requests as they do not need authorization checks on the server
Para optimizar la carga de recursos y tareas en paralelo - To optimize resource loading and parallelize tasks Correct!
Para evitar que el servdor colapse con multiples peticiones - To avoid server crashes due to multiple requests Your Answer
Para evitar que la intefaz de usuario no sea responsive durante la ejecucion de tareas - To avoid your UI becoming unresponsive due to long-running tasks (Correct)
Esa sí es como más teórica y si tiene sentido se supone que con el procesamiento asincrónico es para que vayan cargando otros procesos sin congelarse la pantalla, ¿no? ¿Y si se congela la pantalla se daña e responsive? O no entendí mucho eso último solo ahí me equivoqué.
Disculpen de antemano la traduccion hay cosas que no se traducir muy bien jeje