웹 프론트엔드 JS 튜토리얼 javascript 객체 지향 Javascript 상속_js 객체 지향

javascript 객체 지향 Javascript 상속_js 객체 지향

May 16, 2016 pm 06:28 PM
javascript 상속하다 객체지향

이전 섹션에서는 JavaScript 객체 지향 네임스페이스, javascript 객체 지향 JavaScript 클래스, JavaScript 객체 지향 비공개 멤버 및 공개 멤버에 대해 설명했습니다. 🎜>Javascript 객체 지향 오버로딩, 위 내용을 먼저 읽고 아래 내용을 계속 읽으시면 됩니다.
JavaScript에서 상속을 구현하는 방법에는 여러 가지가 있습니다. 다음은 두 가지 일반적인 방법입니다.

1. 상속 호출, 먼저 코드 살펴보기:
먼저 "사람" 클래스 정의

코드 복사 코드는 다음과 같습니다.
//Human
Person=function(){
this.name="Grass Mud Horse"
this.eat= function(){
Alert("먹고 싶어요");
}
this.sleep=function(){
alert("자고 싶어요")
}
}

다른 학생 클래스를 정의하고 Person

코드 복사 코드는 다음과 같습니다:
//Student 클래스
Student=function(){
Person.call(this);//Person 클래스 상속
this.doHomework=function (){
alert("선생님이 오셨습니다. 숙제 복사하겠습니다");
}
}

핵심은 Person.call 문장을 보는 것입니다. (this)는 현재 객체, 즉 이해하기 쉬운 Student를 나타내며, Person.call(this)은 Person 클래스의 모든 공개 멤버를 Student 클래스에 "연결"한다는 의미입니다. Student는 Person의 모든 기능도 가지고 있습니다.
고급 언어와 마찬가지로 상위 클래스와 동일한 이름을 가진 멤버가 하위 클래스에 나타나면 덮어쓰게 되는데, 이를 소위 "다시 쓰기"라고 합니다.
마찬가지로 소녀 클래스를 정의합니다.

코드 복사 코드는 다음과 같습니다.
//Girl 클래스
Girl=function(){
Person.call(this);//Person 클래스 상속
this.sex="female";
}

JavaScript는 다중 상속을 구현할 수 있습니다. 아래 Master 클래스를 살펴보세요. 이 Master는 원래 학생이지만 동시에 예쁜 소녀이기도 하므로 다음 코드가 있습니다.

코드 복사 코드는 다음과 같습니다.
//Master class
Master=function(){
Student.call(this );//Student 클래스 상속
Girl.call(this);//Girl 클래스 상속
this.degree="석사 학위";//Education

}

테스트할 수 있습니다:

코드 복사 코드는 다음과 같습니다.
var master=new Master ();
master.name="펭 자매";
master.doHomework(); Alert("내 이름은: " master.name);
alert("내 성별은:" master.sex)


다중 상속을 사용할 경우 순서에 주의하세요. 두 클래스의 동일한 이름을 가진 멤버는 후자의 클래스가 이전 클래스를 덮어씁니다. 즉, 현재 클래스는 후자 클래스의 멤버만 상속합니다.
호출 방법 상속에 대한 내용은 여기까지입니다. 자세한 내용은 Google에 문의해 주세요. 온라인에 너무 많이 게시하지 마세요. 또 다른 상속 방법에 대해 이야기해 보겠습니다.
둘째, 프로토타입 프로토타입 상속:
모니터 클래스를 정의해 보겠습니다.



코드 복사 코드는 다음과 같습니다. : //분대장 클래스
SquadLeader=function (){
//안녕하세요
this.hi=function(){
alert("안녕하세요, 동급생 여러분, 저는 이제 분대장입니다.");
}
}


위의 내용은 마스터 클래스를 정의합니다. 이제 이 마스터가 분대장으로 승격되었으므로 이 마스터가 분대장을 상속하게 됩니다. 이번에 프로토타입을 사용하여 구현해 보도록 하겠습니다.


본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.

핫 AI 도구

Undresser.AI Undress

Undresser.AI Undress

사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover

AI Clothes Remover

사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool

Undress AI Tool

무료로 이미지를 벗다

Clothoff.io

Clothoff.io

AI 옷 제거제

AI Hentai Generator

AI Hentai Generator

AI Hentai를 무료로 생성하십시오.

인기 기사

R.E.P.O. 에너지 결정과 그들이하는 일 (노란색 크리스탈)
2 몇 주 전 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. 최고의 그래픽 설정
2 몇 주 전 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. 아무도들을 수없는 경우 오디오를 수정하는 방법
2 몇 주 전 By 尊渡假赌尊渡假赌尊渡假赌

뜨거운 도구

메모장++7.3.1

메모장++7.3.1

사용하기 쉬운 무료 코드 편집기

SublimeText3 중국어 버전

SublimeText3 중국어 버전

중국어 버전, 사용하기 매우 쉽습니다.

스튜디오 13.0.1 보내기

스튜디오 13.0.1 보내기

강력한 PHP 통합 개발 환경

드림위버 CS6

드림위버 CS6

시각적 웹 개발 도구

SublimeText3 Mac 버전

SublimeText3 Mac 버전

신 수준의 코드 편집 소프트웨어(SublimeText3)

C++ 함수 상속에 대한 자세한 설명: 상속에서 '기본 클래스 포인터'와 '파생 클래스 포인터'를 사용하는 방법은 무엇입니까? C++ 함수 상속에 대한 자세한 설명: 상속에서 '기본 클래스 포인터'와 '파생 클래스 포인터'를 사용하는 방법은 무엇입니까? May 01, 2024 pm 10:27 PM

함수 상속에서는 "기본 클래스 포인터" 및 "파생 클래스 포인터"를 사용하여 상속 메커니즘을 이해합니다. 기본 클래스 포인터가 파생 클래스 개체를 가리키는 경우 상향 변환이 수행되고 기본 클래스 멤버에만 액세스됩니다. 파생 클래스 포인터가 기본 클래스 개체를 가리키는 경우 하향 캐스팅이 수행되므로(안전하지 않음) 주의해서 사용해야 합니다.

상속과 다형성은 C++의 클래스 결합에 어떤 영향을 미치나요? 상속과 다형성은 C++의 클래스 결합에 어떤 영향을 미치나요? Jun 05, 2024 pm 02:33 PM

상속과 다형성은 클래스 결합에 영향을 줍니다. 상속은 파생 클래스가 기본 클래스에 종속되기 때문에 결합을 증가시킵니다. 다형성은 객체가 가상 함수와 기본 클래스 포인터를 통해 일관된 방식으로 메시지에 응답할 수 있기 때문에 결합을 줄입니다. 모범 사례에는 상속을 적게 사용하고, 공용 인터페이스를 정의하고, 기본 클래스에 데이터 멤버를 추가하지 않고, 종속성 주입을 통해 클래스를 분리하는 것이 포함됩니다. 다형성과 종속성 주입을 사용하여 은행 계좌 애플리케이션에서 결합을 줄이는 방법을 보여주는 실제 예입니다.

C++ 함수 상속에 대한 자세한 설명: 상속 오류를 디버깅하는 방법은 무엇입니까? C++ 함수 상속에 대한 자세한 설명: 상속 오류를 디버깅하는 방법은 무엇입니까? May 02, 2024 am 09:54 AM

상속 오류 디버깅 팁: 올바른 상속 관계를 확인하세요. 디버거를 사용하여 코드를 단계별로 실행하고 변수 값을 검사합니다. 가상 수정자를 올바르게 사용했는지 확인하세요. 숨겨진 상속으로 인해 발생하는 상속 다이아몬드 문제를 살펴봅니다. 추상 클래스에서 구현되지 않은 순수 가상 함수를 확인하세요.

Go의 객체 지향 프로그래밍 살펴보기 Go의 객체 지향 프로그래밍 살펴보기 Apr 04, 2024 am 10:39 AM

Go 언어는 유형 정의 및 메소드 연관을 통해 객체 지향 프로그래밍을 지원합니다. 전통적인 상속을 지원하지 않지만 구성을 통해 구현됩니다. 인터페이스는 유형 간의 일관성을 제공하고 추상 메소드를 정의할 수 있도록 합니다. 실제 사례에서는 OOP를 사용하여 고객 운영 생성, 획득, 업데이트 및 삭제를 포함하여 고객 정보를 관리하는 방법을 보여줍니다.

PHP 고급 기능: 객체 지향 프로그래밍의 모범 사례 PHP 고급 기능: 객체 지향 프로그래밍의 모범 사례 Jun 05, 2024 pm 09:39 PM

PHP의 OOP 모범 사례에는 명명 규칙, 인터페이스 및 추상 클래스, 상속 및 다형성, 종속성 주입이 포함됩니다. 실제 사례에는 웨어하우스 모드를 사용하여 데이터를 관리하고 전략 모드를 사용하여 정렬을 구현하는 것이 포함됩니다.

Go 언어의 객체지향적 특징 분석 Go 언어의 객체지향적 특징 분석 Apr 04, 2024 am 11:18 AM

Go 언어는 객체 지향 프로그래밍, 구조체를 통한 객체 정의, 포인터 수신기를 사용한 메서드 정의, 인터페이스를 통한 다형성 구현을 지원합니다. 객체 지향 기능은 Go 언어에서 코드 재사용, 유지 관리 용이성 및 캡슐화를 제공하지만 클래스 및 상속 및 메서드 시그니처 캐스트에 대한 전통적인 개념이 부족하다는 제한 사항도 있습니다.

Golang에 클래스와 유사한 객체지향 기능이 있나요? Golang에 클래스와 유사한 객체지향 기능이 있나요? Mar 19, 2024 pm 02:51 PM

Golang(Go 언어)에는 전통적인 의미의 클래스 개념이 없지만, 클래스와 유사한 객체지향 기능을 구현할 수 있는 구조체라는 데이터 형식을 제공합니다. 이 기사에서는 구조를 사용하여 객체 지향 기능을 구현하는 방법을 설명하고 특정 코드 예제를 제공합니다. 구조의 정의와 사용법 먼저 구조의 정의와 사용법을 살펴보자. Golang에서는 type 키워드를 통해 구조를 정의한 다음 필요한 곳에 사용할 수 있습니다. 구조에는 속성이 포함될 수 있습니다.

C++ 함수 상속에 대한 자세한 설명: 상속에서 'is-a' 및 'has-a' 관계를 이해하는 방법은 무엇입니까? C++ 함수 상속에 대한 자세한 설명: 상속에서 'is-a' 및 'has-a' 관계를 이해하는 방법은 무엇입니까? May 02, 2024 am 08:18 AM

C++ 함수 상속에 대한 자세한 설명: "is-a"와 "has-a" 사이의 관계를 마스터하세요. 함수 상속이란 무엇인가요? 함수 상속은 파생 클래스에 정의된 메서드를 기본 클래스에 정의된 메서드와 연결하는 C++의 기술입니다. 파생 클래스가 기본 클래스의 메서드에 액세스하고 재정의할 수 있도록 하여 기본 클래스의 기능을 확장합니다. "is-a" 및 "has-a" 관계 함수 상속에서 "is-a" 관계는 파생 클래스가 기본 클래스의 하위 유형, 즉 파생 클래스가 기본 클래스의 특성과 동작을 "상속"함을 의미합니다. 기본 클래스. "has-a" 관계는 파생 클래스에 기본 클래스 개체에 대한 참조 또는 포인터가 포함되어 있음을 의미합니다. 즉, 파생 클래스가 기본 클래스 개체를 "소유"합니다. 구문다음은 함수 상속을 구현하는 방법에 대한 구문입니다. classDerivedClass:pu

See all articles