Soy nuevo en el uso de clases ES6 con React, anteriormente he estado vinculando mis métodos al objeto actual (mostrar en el primer ejemplo), pero ¿ES6 me permite vincular permanentemente una función de clase a una instancia de clase con flechas? (Útil cuando se pasa como una función de devolución de llamada). Recibo errores cuando trato de usarlos como puede con CoffeeScript:
class SomeClass extends React.Component {
// Instead of this
constructor(){
this.handleInputChange = this.handleInputChange.bind(this)
}
// Can I somehow do this? Am i just getting the syntax wrong?
handleInputChange (val) => {
console.log('selectionMade: ', val);
}
De modo que si tuviera que pasar SomeClass.handleInputChange
a, por ejemplo setTimeout
, se limitaría a la instancia de clase, y no al window
objeto.
Respuestas:
Su sintaxis está ligeramente apagada, solo falta un signo igual después del nombre de la propiedad.
Esta es una característica experimental. Deberá habilitar las funciones experimentales en Babel para que esto se compile. Aquí hay una demostración con experimental habilitado.
Para usar funciones experimentales en babel, puede instalar el complemento correspondiente desde aquí . Para esta característica específica, necesita el
transform-class-properties
complemento :Puede leer más sobre la propuesta de Campos de clase y Propiedades estáticas aquí
fuente
=
a lashandleInputChange =
No, si desea crear métodos vinculados específicos de instancia, deberá hacerlo en el constructor. Sin embargo, puede usar funciones de flecha para eso, en lugar de usar
.bind
un método prototipo:Hay una propuesta que podría permitirle omitir
constructor()
y colocar directamente la asignación en el alcance de la clase con la misma funcionalidad, pero no recomendaría usarla ya que es altamente experimental.Alternativamente, siempre puede usar
.bind
, lo que le permite declarar el método en el prototipo y luego vincularlo a la instancia en el constructor. Este enfoque tiene una mayor flexibilidad ya que permite modificar el método desde el exterior de su clase.fuente
Sé que esta pregunta ha sido suficientemente respondida, pero solo tengo que hacer una pequeña contribución (para aquellos que no quieren usar la función experimental). Debido al problema de tener que vincular enlaces de múltiples funciones en el constructor y hacer que se vea desordenado, se me ocurrió un método de utilidad que una vez vinculado y llamado en el constructor, realiza automáticamente todos los enlaces de métodos necesarios para usted.
Supongamos que tengo esta clase con el constructor:
Se ve desordenado, ¿no? Ahora creé este método de utilidad
Todo lo que tengo que hacer ahora es importar esa utilidad y agregar una llamada a mi constructor, y ya no necesito vincular cada método nuevo en el constructor. El nuevo constructor ahora se ve limpio, así:
fuente
shouldComponentUpdate
ygetSnapshotBeforeUpdate
Está utilizando la función de flecha y también la vincula en el constructor. Por lo tanto, no necesita vincular cuando usa las funciones de flecha
O necesita vincular una función solo en el constructor cuando usa la función normal como se muestra a continuación
Tampoco se recomienda vincular una función directamente en render. Siempre debe estar en constructor
fuente