Tengo una consulta para averiguar si no me estoy equivocando o haciendo una mala práctica del lenguaje. Normalmente tengo que hacer referencia al objeto en el que estoy definiendo algunas o muchas funciones anónimas, pero en estas no tengo acceso a la palabra reservada this, lo cual me crea una estructura del lenguaje bastante compleja y creo (posiblemente) innecesaria.
Como no he visto muchas aplicaciones que lo hagan de la forma como yo lo realizo me pregunto si hay algo que estoy realizando mal, por ejemplo:
Código Javascript:
Ver original
Mesa.prototype.crearTablero = function (ancho, alto, callback) { this.tablero = new Tablero(ancho, alto, (function (mesa) { return function () { mesa.panel = document.getElementById("JPuzzleT"); if (mesa.panel) { mesa.panel.onclick = (function (mesa) { return function (evt) { mesa.mouseClickedHandler(evt); }; })(mesa); callback(); } }; })(this), (function (mesa) { return function (origen, destino) { mesa.stateChangedHandler(origen, destino); }; })(this)); };
En ese caso no me queda mas que crear una función anónima adicional que reciba un parámetro, donde le paso el this (en este caso mesa), para que el closure tenga acceso al this. El ejemplo es de una aplicación algo antigua adaptada de una aplicación que hice en Java, pero todavía se aplica.
Ahora bien, el problema es que ese fue un ejemplo sencillo a veces tengo que declarar muchas funciones que internamente definen muchas funciones y al final en cascada tengo n cantidad de funciones anónimas solamente con el objetivo de tener acceso al this.
¿Existe algún mejor método o patrón que no tenga que estar pasando el this de esa forma?
Saludos,