Tengo un objeto de trabajo algo como esto:
const WorkerObject = { mapProp: new Map(), funA() { // some task }, funB() { // some task }, workerListener() { parentPort.on('message', async (message) => { console.log(this.mapProp) // returning Map(0) {} }) } }
Cuando llamo a la propiedad mapProp
en la devolución de llamada del oyente parentPort()
dentro de la función workListener()
, hace referencia al mapa que asigné en la parte superior del objeto. Esto es justo lo que esperaba.
Pero necesito reducir la complejidad cognitiva, así que muevo la función de devolución de llamada a otra función definida dentro de WorkerObject
.
const WorkerObject = { mapProp: new Map(), funA() { // some task }, funB() { // some task }, async doBulkIndex(message) { console.log(this.mapProp) // returning undefined }, workerListener() { parentPort.on('message', this.doBulkIndex) } }
Pero de alguna manera, ahora el Mapa siempre vuelve indefinido. Básicamente, todas las propiedades a las que intenté acceder dentro de doBulkIndex()
no están definidas. ¿Por qué es así? ¿Y cómo hacer que mi segundo enfoque tenga el mismo comportamiento que el anterior?
el contexto de la devolución de llamada que llama no es el mismo, creo que debería vincular "esto" a él,
workerListener() { parentPort.on('message', this.doBulkIndex.bind(this))}
en el primero, esta palabra clave se refiere a WorkerObject pero en el segundo, se refiere al contexto "doBulkIndex". puede buscar sobre el contexto y enlazar.
entonces cambiamos manualmente el contexto al objeto principal usando bind.