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

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

Dec 13, 2024 am 11:15 AM

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으로 문의하세요.

핫 AI 도구

Undresser.AI Undress

Undresser.AI Undress

사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover

AI Clothes Remover

사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool

Undress AI Tool

무료로 이미지를 벗다

Clothoff.io

Clothoff.io

AI 옷 제거제

AI Hentai Generator

AI Hentai Generator

AI Hentai를 무료로 생성하십시오.

뜨거운 도구

메모장++7.3.1

메모장++7.3.1

사용하기 쉬운 무료 코드 편집기

SublimeText3 중국어 버전

SublimeText3 중국어 버전

중국어 버전, 사용하기 매우 쉽습니다.

스튜디오 13.0.1 보내기

스튜디오 13.0.1 보내기

강력한 PHP 통합 개발 환경

드림위버 CS6

드림위버 CS6

시각적 웹 개발 도구

SublimeText3 Mac 버전

SublimeText3 Mac 버전

신 수준의 코드 편집 소프트웨어(SublimeText3)

JavaScript로 문자열 문자를 교체하십시오 JavaScript로 문자열 문자를 교체하십시오 Mar 11, 2025 am 12:07 AM

JavaScript로 문자열 문자를 교체하십시오

jQuery 날짜가 유효한지 확인하십시오 jQuery 날짜가 유효한지 확인하십시오 Mar 01, 2025 am 08:51 AM

jQuery 날짜가 유효한지 확인하십시오

jQuery는 요소 패딩/마진을 얻습니다 jQuery는 요소 패딩/마진을 얻습니다 Mar 01, 2025 am 08:53 AM

jQuery는 요소 패딩/마진을 얻습니다

10 JQuery Accordions 탭 10 JQuery Accordions 탭 Mar 01, 2025 am 01:34 AM

10 JQuery Accordions 탭

10 JQuery 플러그인을 확인할 가치가 있습니다 10 JQuery 플러그인을 확인할 가치가 있습니다 Mar 01, 2025 am 01:29 AM

10 JQuery 플러그인을 확인할 가치가 있습니다

노드 및 HTTP 콘솔로 HTTP 디버깅 노드 및 HTTP 콘솔로 HTTP 디버깅 Mar 01, 2025 am 01:37 AM

노드 및 HTTP 콘솔로 HTTP 디버깅

사용자 정의 Google 검색 API 설정 자습서 사용자 정의 Google 검색 API 설정 자습서 Mar 04, 2025 am 01:06 AM

사용자 정의 Google 검색 API 설정 자습서

jQuery div에 스크롤 바를 추가합니다 jQuery div에 스크롤 바를 추가합니다 Mar 01, 2025 am 01:30 AM

jQuery div에 스크롤 바를 추가합니다

See all articles