JS 상속 소개
이 글은 주로 참조 가치가 있는 JS 상속에 대한 소개입니다. 이제는 모든 사람과 공유합니다. 도움이 필요한 친구들이 참조할 수 있습니다.
ClassA
두 부분으로 구성됩니다.
생성자 부분에서는 각 인스턴스가 독립적입니다.
프로토타입 부분은 인스턴스별로 공유됩니다.
// 构造函数 function ClassA(sColor) { this.color = sColor; } // 原型 ClassA.prototype.sayColor = function () { alert(this.color); };
인스턴스를 생성합니다.
내부 작업:
이것은 새로운 { }를 가리키고 객체의 __proto__는 ClassA.prototype을 가리킵니다.
ClassA 생성자를 실행합니다.
이 항목이 가리키는 { }를 반환합니다.
var a = new ClassA(); console.log(a.__proto__ === ClassA.prototype); // a 的继承对象指向 ClassA console.log(a.constructor === ClassA);
프로토타입 부분 상속
function ClassB() { // 实现继承 ClassA 构造函数部分的继承 } ClassB.prototype = new ClassA(); // ClassB.prototype 指向新对象时,原有的 ClassB.constructor 属性会消失。 // new ClassA().hasOwnProperty('constructor') 为 false,新生成的对象无 constructor 属性。 // 在此修复这个问题。 ClassB.constructor = ClassB; // 不过还存在 new ClassA().hasOwnProperty('color') 为 true 问题 // 实现继承 ClassA 构造函数部分的继承,生成的属性优先级比 new ClassA().color 高,顾可以忽略
생성자 부분 상속 - 객체 가장
ClassA를 ClassB에 메소드로 도입하는데, 이때 둘은 이것을 공유합니다.
ClassA 생성자를 실행합니다.
임시 소개를 삭제합니다.
function ClassB(sColor) { this.newMethod = ClassA; this.newMethod(sColor); delete this.newMethod; }
생성자 부분 상속-apply/call/bind
객체 가장의 함수 구현입니다.
ClassB의 this를 ClassA의 this에 바인딩하고 생성자 ClassA를 실행합니다.
function ClassB(sColor) { ClassA.call(this, sColor); // 以下两种方式效果一样,只是实现方式不同 // ClassA.apply(this, [sColor]); // ClassA.bind(this, sColor)(); }
Inheritance
상속은 생성자 상속과 프로토타입 상속의 두 부분으로 구성됩니다. 상속 방법의 조합을 선택할 수 있습니다.
생성자 프로토타입의 --constructor 속성은 항상 생성자 자체를 가리킵니다. 상속시 수정된 경우 마지막에 수정해주세요.
상속은 원래 기능을 유지하므로 상속 후 새 생성자 또는 프로토타입 속성을 확장할 수 있습니다.
날짜 상속
// 需要考虑polyfill情况 Object.setPrototypeOf = Object.setPrototypeOf || function(obj, proto) { obj.__proto__ = proto; return obj; }; /** * 用了点技巧的继承,实际上返回的是Date对象 */ function MyDate() { // bind属于Function.prototype,接收的参数是:object, param1, params2... var dateInst = new(Function.prototype.bind.apply(Date, [null].concat(Array.prototype.slice.call(arguments))))(); // 更改原型指向,否则无法调用MyDate原型上的方法 // ES6方案中,这里就是[[prototype]]这个隐式原型对象,在没有标准以前就是__proto__ Object.setPrototypeOf(dateInst, MyDate.prototype); dateInst.abc = 1; return dateInst; } // 原型重新指回Date,否则根本无法算是继承 Object.setPrototypeOf(MyDate.prototype, Date.prototype); MyDate.prototype.getTest = function getTest() { return this.getTime(); }; let date = new MyDate(); // 正常输出,譬如1515638988725 console.log(date.getTest());
// 继承的重点语句 var dateInst = new(Function.prototype.bind.apply(Date, [null].concat(Array.prototype.slice.call(arguments))))(); // 使用经典方法实现继承的时候,由于 Date 是内部对象,使用上有限制 // 提示 “this is not a Date object” // 说明 Date 上的方法只能由 Date 的实例调用,它会识别内部的 [[class]],浏览器无法修改。 // 所以想到了如下方案 var dateInst = new Date(...arguments); // 能实现构造函数的只有 bind var dateInst = new (Date.bind(null, ...arguments))(); // ES5下无法实现 ...,只能转成数组 [null].concat(Array.prototype.slice.call(arguments)); // 参数中带数组的只有 ayyly var dateInst = new (Function.prototype.bind.apply(Date, [null].concat(Array.prototype.slice.call(arguments))))();
이상이 이 글의 전체 내용입니다. 더 많은 관련 내용을 보시려면 PHP 중국어 웹사이트를 주목해주세요!
관련 권장사항:
위 내용은 JS 상속 소개의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

핫 AI 도구

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

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

Undress AI Tool
무료로 이미지를 벗다

Clothoff.io
AI 옷 제거제

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

인기 기사

뜨거운 도구

메모장++7.3.1
사용하기 쉬운 무료 코드 편집기

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

스튜디오 13.0.1 보내기
강력한 PHP 통합 개발 환경

드림위버 CS6
시각적 웹 개발 도구

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

뜨거운 주제











기사는 JavaScript 라이브러리 작성, 게시 및 유지 관리, 계획, 개발, 테스트, 문서 및 홍보 전략에 중점을 둡니다.

이 기사는 브라우저에서 JavaScript 성능을 최적화하기위한 전략에 대해 설명하고 실행 시간을 줄이고 페이지로드 속도에 미치는 영향을 최소화하는 데 중점을 둡니다.

프론트 엔드 개발시 프론트 엔드 열지대 티켓 인쇄를위한 자주 묻는 질문과 솔루션, 티켓 인쇄는 일반적인 요구 사항입니다. 그러나 많은 개발자들이 구현하고 있습니다 ...

이 기사는 브라우저 개발자 도구를 사용하여 효과적인 JavaScript 디버깅, 중단 점 설정, 콘솔 사용 및 성능 분석에 중점을 둡니다.

이 기사는 소스 맵을 사용하여 원래 코드에 다시 매핑하여 미니어링 된 JavaScript를 디버그하는 방법을 설명합니다. 소스 맵 활성화, 브레이크 포인트 설정 및 Chrome Devtools 및 Webpack과 같은 도구 사용에 대해 설명합니다.

기술 및 산업 요구에 따라 Python 및 JavaScript 개발자에 대한 절대 급여는 없습니다. 1. 파이썬은 데이터 과학 및 기계 학습에서 더 많은 비용을 지불 할 수 있습니다. 2. JavaScript는 프론트 엔드 및 풀 스택 개발에 큰 수요가 있으며 급여도 상당합니다. 3. 영향 요인에는 경험, 지리적 위치, 회사 규모 및 특정 기술이 포함됩니다.

이 튜토리얼은 Chart.js를 사용하여 파이, 링 및 버블 차트를 만드는 방법을 설명합니다. 이전에는 차트 유형의 차트 유형을 배웠습니다. JS : 라인 차트 및 막대 차트 (자습서 2)와 레이더 차트 및 극지 지역 차트 (자습서 3)를 배웠습니다. 파이 및 링 차트를 만듭니다 파이 차트와 링 차트는 다른 부분으로 나뉘어 진 전체의 비율을 보여주는 데 이상적입니다. 예를 들어, 파이 차트는 사파리에서 남성 사자, 여성 사자 및 젊은 사자의 비율 또는 선거에서 다른 후보자가받는 투표율을 보여주는 데 사용될 수 있습니다. 파이 차트는 단일 매개 변수 또는 데이터 세트를 비교하는 데만 적합합니다. 파이 차트의 팬 각도는 데이터 포인트의 숫자 크기에 의존하기 때문에 원형 차트는 값이 0 인 엔티티를 그릴 수 없습니다. 이것은 비율이 0 인 모든 엔티티를 의미합니다

Console.log 출력의 차이의 근본 원인에 대한 심층적 인 논의. 이 기사에서는 Console.log 함수의 출력 결과의 차이점을 코드에서 분석하고 그에 따른 이유를 설명합니다. � ...
