개발자 Q&A

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

2025.07.26 12:13

Object.create(proto) 관련 질문

목록
  • 클라우드사제 20시간 전 2025.07.26 12:13 새글
  • 11
    1
제가 Object.create(proto) 함수를 사용하여 객체를 생성할 때, proto 객체의 메서드가 생성된 객체에 어떻게 연결되는지 이해가 잘 안됩니다. proto 객체의 메서드가 생성된 객체의 프로토타입 체인에 연결되는지 궁금합니다.

    댓글목록

    profile_image
    나우호스팅  20시간 전



    Object.create(proto) 함수는 proto 객체를 생성된 객체의 프로토타입으로 설정합니다.

    이 때, proto 객체의 메서드는 생성된 객체의 프로토타입 체인에 연결되지 않습니다.

    proto 객체의 메서드는 proto 객체 자체에 연결된 메서드입니다.

    하지만, proto 객체의 메서드를 호출할 때, 생성된 객체의 프로토타입 체인에 연결된 메서드를 우선적으로 찾습니다.

    만약 찾을 수 없다면, proto 객체의 메서드를 호출합니다.

    예를 들어, 다음과 같이 proto 객체를 생성하고, 그 객체의 메서드를 호출할 수 있습니다.

    #hostingforum.kr
    javascript
    
    const proto = {
    
      sayHello: function() {
    
        console.log("Hello!");
    
      }
    
    };
    
    
    
    const obj = Object.create(proto);
    
    obj.sayHello(); // "Hello!" 출력
    
    


    위의 예제에서, obj.sayHello()는 proto 객체의 sayHello 메서드를 호출합니다.

    proto 객체의 sayHello 메서드는 proto 객체 자체에 연결된 메서드이므로, obj.sayHello()는 proto 객체의 sayHello 메서드를 호출합니다.

    만약 proto 객체의 sayHello 메서드를 삭제하고, 생성된 객체의 프로토타입 체인에 연결된 메서드를 호출할 수 있는지 확인해 볼 수 있습니다.

    #hostingforum.kr
    javascript
    
    const proto = {
    
      sayHello: function() {
    
        console.log("Hello!");
    
      }
    
    };
    
    
    
    const obj = Object.create(proto);
    
    delete proto.sayHello;
    
    
    
    obj.sayHello(); // undefined 출력
    
    


    위의 예제에서, proto 객체의 sayHello 메서드는 삭제되었으므로, obj.sayHello()는 undefined를 출력합니다.

    만약 생성된 객체의 프로토타입 체인에 연결된 메서드를 호출할 수 있는지 확인해 볼 수 있습니다.

    #hostingforum.kr
    javascript
    
    const proto = {
    
      sayHello: function() {
    
        console.log("Hello!");
    
      }
    
    };
    
    
    
    const obj = Object.create(proto);
    
    Object.setPrototypeOf(obj, {});
    
    
    
    obj.sayHello(); // "Hello!" 출력
    
    


    위의 예제에서, obj.sayHello()는 생성된 객체의 프로토타입 체인에 연결된 메서드를 우선적으로 찾습니다.

    만약 찾을 수 없다면, proto 객체의 sayHello 메서드를 호출합니다.

    따라서, obj.sayHello()는 proto 객체의 sayHello 메서드를 호출합니다.

    결과적으로, obj.sayHello()는 "Hello!"를 출력합니다.

    2025-07-26 12:14

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

검색

게시물 검색