> 웹 프론트엔드 > JS 튜토리얼 > Javascript 언어의 다형성이란 무엇입니까?

Javascript 언어의 다형성이란 무엇입니까?

小云云
풀어 주다: 2018-01-29 13:45:56
원래의
2442명이 탐색했습니다.

Java 언어는 코드를 컴파일할 때 엄격한 유형 검사로 인해 변수에 다른 유형의 값을 할당할 수 없습니다. 이러한 유형 검사는 코드를 엄격하게 만들지 만 Java는 상속을 통과하여 다음과 같은 효과도 얻을 수 있습니다. 다형성(구현 상속 및 인터페이스 상속)이며 다형성을 달성하기 위해 위쪽으로 변환될 수 있습니다.

다형성의 실제 의미는 동일한 작업이 다른 개체에 작용하여 다른 해석과 다른 실행 결과를 생성할 수 있다는 것입니다. JavaScript의 변수 유형은 런타임에 가변적입니다. 이는 JavaScript 개체의 다형성이 내재되어 있음을 의미합니다.

다음 사진은 이를 설명합니다.

주인은 닭과 오리에게 동시에 "울어라" 명령을 내립니다. 닭과 오리는 동시에 울지만 울음소리는 다릅니다.
Javascript 언어의 다형성이란 무엇입니까?

이 예제를 설명하기 위해 코드를 사용합니다.

기존 코드에서는 하드 코딩된 코드를 쌓기 위해 if else를 사용했지만 이 개체가 계속해서 추가되면 코드가 계속해서 추가됩니다. 그리고 코드를 수정하는 것은 항상 매우 위험합니다. 수정이 많을수록 프로그램 오류가 발생할 가능성이 커집니다. 또한, 동물의 종류가 많아지면 다른 기능이 쌓여서 도움이 되지 않습니다. 유지 보수에.

var makeSound = function(animal) {
     if (animal instanceof Dog) {
        console.log('wanwan');
     } else if(animal instanceof Cat) {
        console.log('miaomiao');
     }
}

var Dog = function() {}
var Cat = function() {}
makeSound(new Dog());
makeSound(new Cat());
로그인 후 복사

수정된 코드는 다음과 같습니다.

 var makeSound = function(animal) {
     animal.sound();
}
var Dog = function() {}
Dog.prototype.sound = function(){
   console.log('wanwan');
}

var Cat = function() {}
Cat.prototype.sound = function() {
   console.log('miaomiao');
}
makeSound(new Dog());
makeSound(new Cat());
로그인 후 복사

객체가 요청에 응답할 수 없는 경우 해당 요청을 생성자의 프로토타입에 위임한다는 것을 이해하는 방법은 다음과 같이 프로토타입 상속의 핵심입니다. 코드 조각:

var obj = {name:'lin'};

var A = function() {};

A.prototype = obj;

var a = new A();
console.log ( a.name);

설명: 객체 a의 모든 속성을 탐색했지만 속성 이름을 찾을 수 없습니다
이름 속성을 찾는 요청은 a에 의해 기록된 객체 a 생성자의 프로토타입에 위임됩니다. _proto_는 A.prototype을 가리키고,
그리고 A.prototype은 객체 obj로 설정됩니다
객체 obj에서 name 속성을 찾아서 반환합니다.

관련 권장 사항:

JavaScript 언어를 배우는 방법은 무엇입니까? 학습에 있어 중요한 점과 어려운 점은 무엇인가요?

자바스크립트 언어 구조에 대한 주의사항(1)_기초 지식

자바스크립트 언어의 기본 문법 요구 사항에 대한 자세한 설명_기본 지식


위 내용은 Javascript 언어의 다형성이란 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

관련 라벨:
원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿