GoF가 제안한 유명한 코드 재사용 원칙이 있습니다. 클래스 상속보다 객체 구성에 우선순위를 두는 것입니다. JavaScript에는 클래스 개념이 없으므로 코드 재사용은 클래스 상속에만 국한되지 않습니다. JavaScript에는 객체를 생성하는 방법이 많이 있으며, new를 사용하여 객체를 생성할 수 있고 객체를 동적으로 수정할 수 있습니다. JavaScript의 비클래스 상속(현대 상속 모델이라고도 함)에는 다른 객체를 사용하여 필수 객체로 결합, 객체 혼합 기술, 필수 메소드 차용 및 재사용 등 많은 재사용 방법이 있습니다.
클래스 상속 모드-기본 모드
부모와 자식 두 생성자의 예:
다음은 재사용 가능한 상속 함수인 Inherit()의 구현 방법입니다.
여기서 프로토타입 특성은 함수가 아닌 객체를 가리켜야 하므로 생성자 자체가 아닌 상위 생성자가 만든 인스턴스를 가리켜야 합니다.
이후 Child 객체가 생성되면 프로토타입을 통해 Parent 인스턴스에서 해당 기능을 가져옵니다.
상속 호출 후 프로토타입 체인:
어린이의 추가 속성 추가:
프로토타입 체인 변경 사항:
자신이 소유한 개체의 속성에서 이름을 찾을 수 있으므로 프로토타입 체인을 찾을 필요가 없습니다.
위 패턴을 사용할 때의 단점 중 하나는 두 객체의 속성, 즉 여기에 추가된 속성과 프로토타입 속성이 동시에 상속된다는 것입니다. 대부분의 경우 이러한 자체 속성은 필요하지 않습니다.
또 다른 단점은 상속() 상속을 사용할 때 하위 생성자에 매개변수 전달을 지원하지 않는다는 것입니다. 예를 들면 다음과 같습니다.
이러한 결과는 예상되지 않습니다. 하위 생성자가 상위 생성자에 매개변수를 전달할 수 있지만 이 상속 메커니즘은 하위 개체가 필요할 때마다 다시 실행되어야 하며 결국 상위 개체가 재창조되었습니다.
이 글은 앞으로 JavaScript 코드 재사용 모드의 다른 모드를 계속 업데이트할 예정입니다.