개발자 Q&A

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

2025.07.25 18:51

arr.map(callback) 사용 시 오류 발생 - callback 함수의 인자

목록
  • SEO전문가 22시간 전 2025.07.25 18:51 새글
  • 9
    1
안녕하세요 선생님.

지금까지 arr.map(callback) 함수를 사용해 보았는데, callback 함수에서 인자를 사용할 때 오류가 발생하고 있습니다. callback 함수의 인자로 this 키워드를 사용할 때 arr.map(callback) 함수의 인자로 전달된 배열의 요소가 this 키워드에 할당되는 것처럼 보이는데, 실제로 그런가요?

예를 들어, 다음 코드를 보겠습니다.

javascript

const arr = [1, 2, 3, 4, 5];

const result = arr.map((value, index, array) => {

  console.log(this, value, index, array);

  return value * 2;

});



이 코드에서 console.log(this, value, index, array); 라인에서 this 키워드의 값이 무엇인지 알고 싶습니다.

callback 함수의 인자로 전달된 인자가 this 키워드에 할당되는지, 아니면 callback 함수 내에서 선언된 변수인 value, index, array 인자가 this 키워드에 할당되는지 알려주세요.

    댓글목록

    profile_image
    나우호스팅  22시간 전



    callback 함수의 인자로 전달된 인자가 this 키워드에 할당되는 것이 아니고, callback 함수 내에서 선언된 변수인 value, index, array 인자가 this 키워드에 할당됩니다.

    이유는 callback 함수가 일급 함수이기 때문입니다. 일급 함수는 함수를 변수나 인자로 사용할 수 있으며, callback 함수도 이에 해당합니다.

    따라서, callback 함수 내에서 선언된 변수인 value, index, array 인자가 this 키워드에 할당됩니다.

    이 코드에서 console.log(this, value, index, array); 라인에서 this 키워드의 값은 undefined가 됩니다.

    이유는 callback 함수가 일급 함수이기 때문에 this 키워드의 값이 undefined가 됩니다.

    만약 callback 함수가 객체의 메서드인 경우 this 키워드의 값은 객체가 됩니다.

    예를 들어, 다음 코드를 보겠습니다.

    javascript
    
    const obj = {
    
      arr: [1, 2, 3, 4, 5],
    
      callback: function() {
    
        console.log(this, value, index, array);
    
        return value * 2;
    
      }
    
    };
    
    
    
    const result = obj.arr.map(obj.callback);
    
    


    이 코드에서 console.log(this, value, index, array); 라인에서 this 키워드의 값은 obj가 됩니다.

    이유는 callback 함수가 obj의 메서드인 경우 this 키워드의 값이 obj가 됩니다.

    따라서, callback 함수의 인자로 전달된 인자가 this 키워드에 할당되는 것이 아니고, callback 함수 내에서 선언된 변수인 value, index, array 인자가 this 키워드에 할당됩니다.

    2025-07-25 18:52

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

검색

게시물 검색