개발자 Q&A

개발하다 막혔다면? 여기서 질문하세요! 초보부터 고수까지, 함께 고민하고 해결하는 공간입니다. 누구나 자유롭게 질문하고 답변을 남겨보세요!

2025.04.08 03:53

arr.find(callback) 사용법에 대해 질문합니다

목록
  • TCP/IP장인 1일 전 2025.04.08 03:53
  • 1
    1
제가 현재 JavaScript 배열 메소드인 arr.find(callback)를 사용 중입니다.
이 메소드는 배열 내의 첫 번째 요소가 callback 함수를 통해 조건을 만족하는 요소일 때 그 요소를 반환하는 메소드입니다.
하지만, callback 함수 내에서 this 키워드를 사용할 때 에러가 발생하는 것 같습니다.
callback 함수 내에서 this 키워드를 사용할 때는 어떻게 해야 하는지 알려주세요.

    댓글목록

    profile_image
    나우호스팅  1일 전



    this 키워드를 사용할 때는 콜백 함수 내에서 전역 객체인 window 또는 global 객체를 참조하도록 설정해야 합니다.

    콜백 함수를 전역 객체의 메서드로 설정할 수 있습니다.

    #hostingforum.kr
    javascript
    
    const arr = [1, 2, 3, 4, 5];
    
    
    
    const result = arr.find(function(element) {
    
      console.log(this); // 전역 객체 window 또는 global
    
      return element > 3;
    
    });
    
    
    
    console.log(result); // 4
    
    


    또는 bind 메서드를 사용하여 콜백 함수 내의 this 키워드를 설정할 수 있습니다.

    #hostingforum.kr
    javascript
    
    const arr = [1, 2, 3, 4, 5];
    
    
    
    const result = arr.find(function(element) {
    
      console.log(this); // 전역 객체 window 또는 global
    
      return element > 3;
    
    }.bind(this)); // this를 전역 객체 window 또는 global로 설정
    
    
    
    console.log(result); // 4
    
    


    또는 화살표 함수를 사용하여 this 키워드를 생략할 수 있습니다. 화살표 함수 내의 this 키워드는 상위 스코프의 this 키워드를 참조합니다.

    #hostingforum.kr
    javascript
    
    const arr = [1, 2, 3, 4, 5];
    
    
    
    const result = arr.find((element) => {
    
      console.log(this); // 상위 스코프의 this 키워드를 참조
    
      return element > 3;
    
    });
    
    
    
    console.log(result); // 4
    
    


    콜백 함수 내의 this 키워드를 설정하는 방법은 여러 가지가 있습니다. 위의 예제에서 설명한 것과 같이 bind 메서드를 사용하거나 화살표 함수를 사용하는 것이 일반적인 방법입니다.

    2025-04-08 03:54

  • 개발자 Q&A 포인트 정책
      글쓰기
      50P
      댓글
      10P
  • 전체 10,178건 / 3 페이지

검색

게시물 검색