> 웹 프론트엔드 > JS 튜토리얼 > jQuery 클릭 핸들러 및 ES6 화살표 기능과 함께 `$(this)`를 올바르게 사용하는 방법은 무엇입니까?

jQuery 클릭 핸들러 및 ES6 화살표 기능과 함께 `$(this)`를 올바르게 사용하는 방법은 무엇입니까?

Linda Hamilton
풀어 주다: 2024-12-07 22:11:12
원래의
370명이 탐색했습니다.

How to Correctly Use `$(this)` with jQuery Click Handlers and ES6 Arrow Functions?

jQuery $(this) 및 ES6 화살표 함수

ES6 화살표 함수는 어휘 this 바인딩을 제공하지만 다음과 함께 사용하면 문제가 될 수 있습니다. jQuery 클릭 바인딩. 이 시나리오에서 화살표 기능을 사용할 때 $(this)는 다르게 동작하여 기본적으로 ES5 폐쇄 동작을 에뮬레이션합니다.

this._pads.on('click', () => {
  if (this.go) { $(this).addClass('active'); }
});
로그인 후 복사

이 문제를 해결하려면 Traceur에 $(를 무시할 수 있는 기능이 없다는 점을 이해하는 것이 중요합니다. this) 이 맥락에서 어휘 바인딩을 위한 것입니다. ES6는 화살표 함수의 동작을 지시하며 본질적으로 어휘 this에 대한 액세스가 부족합니다.

해결책은 $(this):

this._pads.on('click', (event) => {
  if (this.go) {
    $(event.currentTarget).addClass('active');
  }
});
로그인 후 복사

대신 event.currentTarget을 사용하는 것입니다. jQuery는 이벤트를 제공합니다. .currentTarget은 특히 이 목적을 위해 사용됩니다. 어휘에 대한 액세스가 콜백 함수로는 항상 가능한 것은 아니라는 점을 인식하기 때문입니다. event.currentTarget을 활용하면 올바른 요소가 타겟팅되므로 이 바인딩을 수정하거나 ES5 코드에 대한 종속성을 도입할 필요가 없습니다.

위 내용은 jQuery 클릭 핸들러 및 ES6 화살표 기능과 함께 `$(this)`를 올바르게 사용하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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