JavaScript 상속: Object.create와 new
JavaScript의 상속 개념은 혼란스러울 수 있습니다. 그것. 이 문서의 목적은 가장 널리 사용되는 방법을 명확히 하고 특정 시나리오에 대한 솔루션을 제공하는 것입니다.
Object.create 및 new 이해
Object.create는 다음을 생성하는 방법입니다. 기존 개체를 상속하여 새 개체를 만듭니다. 이는 기본 개체를 만든 다음 추가 속성 및 메서드를 사용하여 확장하려는 경우에 유용합니다. Object.create의 구문은 다음과 같습니다.
Object.create(prototype[, propertiesObject])
반면에 new 키워드는 객체의 새 인스턴스를 생성하고 호출하는 데 사용됩니다. 생성자 함수입니다. new의 구문은 다음과 같습니다.
new ConstructorFunction([arguments])
상속을 위한 올바른 방법 선택
Object.create와 Object.create 사이의 선택 새로운 것은 귀하의 특정 요구 사항에 따라 다릅니다. Object.create는 생성자를 호출하지 않고 상속하려는 기본 개체를 만드는 데 이상적입니다. 예:
const Model = { // Base object properties and methods... }; const RestModel = Object.create(Model);
그러나 상속 객체에서 기본 객체의 생성자 함수를 호출하려면 new를 사용해야 합니다. 예:
function Model() { // Base object constructor... } function RestModel() { Model.call(this); // Additional properties and methods... }
시나리오에 대한 솔루션
귀하의 경우에는 Model 기본 개체에서 RestModel을 상속하려고 합니다. Object.create를 사용하여 이를 달성하려면 다음을 수행합니다.
RestModel.prototype = Object.create(Model.prototype);
이것은 다음을 상속하는 새로운 RestModel 프로토타입을 생성합니다. 모델 프로토타입.
부인 성명: 제공된 모든 리소스는 부분적으로 인터넷에서 가져온 것입니다. 귀하의 저작권이나 기타 권리 및 이익이 침해된 경우 자세한 이유를 설명하고 저작권 또는 권리 및 이익에 대한 증거를 제공한 후 이메일([email protected])로 보내주십시오. 최대한 빨리 처리해 드리겠습니다.
Copyright© 2022 湘ICP备2022001581号-3