> 웹 프론트엔드 > JS 튜토리얼 > ES6 화살표 함수가 React에서 클래스 메서드를 영구적으로 바인딩할 수 있나요?

ES6 화살표 함수가 React에서 클래스 메서드를 영구적으로 바인딩할 수 있나요?

Patricia Arquette
풀어 주다: 2024-12-13 11:15:10
원래의
242명이 탐색했습니다.

Can ES6 Arrow Functions Permanently Bind Class Methods in React?

ES6 클래스의 화살표 함수를 클래스 메서드로 활용하는 방법

처음 ES6 클래스를 React에 통합할 때 인스턴스를 바인딩하는 것이 일반적이었습니다. 명시적으로 메서드를 사용합니다(아래 예에 설명된 대로). 그러나 중요한 질문이 생깁니다. ES6에서는 화살표 함수를 사용하여 클래스 함수를 클래스 인스턴스에 영구적으로 바인딩하여 콜백으로의 사용을 단순화하는 것이 가능합니까?

class SomeClass extends React.Component {
  // Bound method
  constructor() {
    this.handleInputChange = this.handleInputChange.bind(this);
  }
}
로그인 후 복사

CoffeeScript는 이 기능을 제공하지만, 여부는 불분명합니다. ES6에서도 비슷한 것을 얻을 수 있습니다.

class SomeClass extends React.Component {
  // Attempted arrow function binding
  handleInputChange(val) => {
    console.log('selectionMade: ', val);
  }
}
로그인 후 복사

이 질문은 화살표 함수가 ES6 내의 클래스 인스턴스에 영구적으로 바인딩되어 다음을 수행할 수 있는지 이해하려고 합니다. 콜백 함수로 쉽게 활용하여 setTimeout과 같은 함수에 전달될 때 올바른 컨텍스트를 보장합니다.

해결책: 구문 수정

다음을 사용하여 클래스 메서드를 정의하려는 원래 시도 화살표 함수에 사소한 구문 오류가 있습니다. 올바른 구문은 다음과 같습니다.

class SomeClass extends React.Component {
  handleInputChange = (val) => {
    console.log('selectionMade: ', val);
  }
}
로그인 후 복사

이 구문을 사용하려면 성공적인 컴파일을 위해 Babel 내에서 실험적 기능을 활성화해야 한다는 점에 유의하는 것이 중요합니다. 필요한 플러그인(transform-class-properties)을 설치하면 이러한 실험적 기능을 활성화할 수 있습니다.

또한 공식 제안 문서에서 클래스 필드 및 정적 속성에 대한 포괄적인 토론을 찾을 수 있습니다.

위 내용은 ES6 화살표 함수가 React에서 클래스 메서드를 영구적으로 바인딩할 수 있나요?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
저자별 최신 기사
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿