자바스크립트에서 oop를 작성하는 방법
웹 개발에서 JavaScript는 매우 인기 있는 프로그래밍 언어가 되었습니다. JavaScript에서는 객체지향 프로그래밍(OOP)이 중요한 개념입니다. OOP를 사용하면 코드를 구조화하고 중복을 줄여 유지 관리 및 확장을 더 쉽게 만들 수 있습니다. 이 기사에서는 JavaScript로 OOP를 작성하는 방법을 소개합니다.
- 프로토타입 및 생성자
자바스크립트에서는 프로토타입을 통해 객체의 속성과 메서드를 공유할 수 있으며, 생성자를 사용하여 새 객체를 생성하고 속성을 초기화합니다. 다음은 생성자와 프로토타입을 사용하는 간단한 예입니다.
function Person(name, age) { this.name = name; this.age = age; } Person.prototype.sayHi = function() { console.log("Hi, my name is " + this.name + " and I'm " + this.age + " years old."); } var person1 = new Person("John", 30); var person2 = new Person("Mary", 25); person1.sayHi(); // Hi, my name is John and I'm 30 years old. person2.sayHi(); // Hi, my name is Mary and I'm 25 years old.
위 예에서는 name
및 age
를 초기화하는 Person
생성자를 정의합니다. 기인하다. 그런 다음 Person.prototype
을 사용하여 각 Person
개체에 sayHi
메서드를 추가합니다. 이 메서드는 모든 Person<에서 사용할 수 있습니다. /code> 코드>객체 공유. 마지막으로 두 개의 <code>Person
개체를 만들고 해당 개체의 sayHi
메서드를 호출했습니다. Person
构造函数,初始化了name
和age
属性。然后,我们使用Person.prototype
给每个Person
对象添加了一个sayHi
方法,这个方法可以被所有Person
对象共享。最后,我们创建了两个Person
对象,并调用了它们的sayHi
方法。
- 类(class)
在ES6中,JavaScript引入了类的概念,并使用关键字class
来实现。类提供了一种更简洁、更易于理解的语法,用于定义对象。
以下是一个使用类的例子:
class Person { constructor(name, age) { this.name = name; this.age = age; } sayHi() { console.log("Hi, my name is " + this.name + " and I'm " + this.age + " years old."); } } let person1 = new Person("John", 30); let person2 = new Person("Mary", 25); person1.sayHi(); // Hi, my name is John and I'm 30 years old. person2.sayHi(); // Hi, my name is Mary and I'm 25 years old.
在上面的例子中,我们使用class
关键字定义了一个Person
类,并在constructor
方法中初始化了name
和age
属性。然后,我们定义了一个sayHi
方法,用于输出一个招呼。最后,我们创建了两个Person
对象,并调用了它们的sayHi
方法。
- 继承(inheritance)
在OOP中,继承是指从一个已有的对象中派生出一个新的对象,新对象继承了原来的对象的属性和方法。在JavaScript中,继承可以通过使用prototype
和class
来实现。
以下是使用prototype
实现继承的例子:
function Person(name, age) { this.name = name; this.age = age; } Person.prototype.sayHi = function () { console.log("Hi, my name is " + this.name + " and I'm " + this.age + " years old."); } function Student(name, age, major) { Person.call(this, name, age); this.major = major; } Student.prototype = Object.create(Person.prototype); Student.prototype.constructor = Student; Student.prototype.sayMajor = function() { console.log("My major is " + this.major + "."); } let person1 = new Person("John", 30); let student1 = new Student("Mary", 25, "Computer Science"); person1.sayHi(); // Hi, my name is John and I'm 30 years old. student1.sayHi(); // Hi, my name is Mary and I'm 25 years old. student1.sayMajor(); // My major is Computer Science.
在上面的例子中,我们定义了一个Person
构造函数,在原型中添加了sayHi
方法。另外,我们定义了一个Student
构造函数,通过使用call
方法调用了Person
构造函数来初始化name
和age
属性,并添加了一个major
属性。然后,我们使用Object.create
方法创建了一个Person.prototype
的副本,并将其指定给Student.prototype
,以便Student
对象可以继承Person
对象的属性和方法。最后,我们定义了一个sayMajor
方法,用于输出学生的专业。最终,我们创建了一个Person
对象和一个Student
对象,并调用了他们的方法。
以下是使用class
实现继承的例子:
class Person { constructor(name, age) { this.name = name; this.age = age; } sayHi() { console.log("Hi, my name is " + this.name + " and I'm " + this.age + " years old.") } } class Student extends Person { constructor(name, age, major) { super(name, age); this.major = major; } sayMajor() { console.log("My major is " + this.major + "."); } } let person1 = new Person("John", 30); let student1 = new Student("Mary", 25, "Computer Science"); person1.sayHi(); // Hi, my name is John and I'm 30 years old. student1.sayHi(); // Hi, my name is Mary and I'm 25 years old. student1.sayMajor(); // My major is Computer Science.
在上面的例子中,我们定义了一个Person
类,在constructor
方法中初始化了name
和age
属性,并在sayHi
方法中输出了一个招呼。然后,我们使用extends
关键字创建了一个Student
类,并使用super
关键字调用了Person
类的constructor
方法来初始化name
和age
属性,并添加了一个major
属性。最后,我们定义了一个sayMajor
方法,用于输出学生的专业。最终,我们创建了一个Person
对象和一个Student
对象,并调用了他们的方法。
结论:
在JavaScript中,OOP是一种非常重要的概念,使用对象、构造函数、原型和类可以更好地组织代码和减少重复性。继承可以通过原型和类来实现。从ES6开始,JavaScript引入了关键字class
- Class (class)🎜🎜🎜ES6에서 JavaScript는 클래스 개념을 도입하고 이를 구현하기 위해
class
키워드를 사용했습니다. 클래스는 객체 정의를 위한 더 명확하고 이해하기 쉬운 구문을 제공합니다. 🎜🎜다음은 클래스 사용 예입니다. 🎜rrreee🎜위 예에서는 class
키워드를 사용하여 Person
클래스를 정의하고 에 추가했습니다. >constructor <code>name
및 age
속성은 메서드에서 초기화됩니다. 그런 다음 인사말을 출력하기 위해 sayHi
메서드를 정의했습니다. 마지막으로 두 개의 Person
개체를 만들고 해당 개체의 sayHi
메서드를 호출했습니다. 🎜- 🎜상속🎜🎜🎜OOP에서 상속이란 기존 객체에서 새 객체를 파생시키는 것을 의미합니다. 새 객체는 원래 객체의 속성과 메서드를 상속합니다. JavaScript에서는
prototype
및 class
를 사용하여 상속을 구현할 수 있습니다. 🎜🎜다음은 프로토타입
을 사용하여 상속을 구현하는 예입니다. 🎜rrreee🎜위 예에서는 Person
생성자를 정의하고 프로토타입 sayHi에 를 추가합니다.
방법. 또한 Student
생성자를 정의하고 call
메서드를 사용하여 Person
생성자를 호출하여 name
및 age 속성을 추가하고 major
속성을 추가했습니다. 그런 다음 Object.create
메서드를 사용하여 Person.prototype
의 복사본을 만들고 이를 Student.prototype
에 할당하여 Student 개체는 <code>Person
개체의 속성과 메서드를 상속할 수 있습니다. 마지막으로 학생의 전공을 출력하기 위해 sayMajor
메소드를 정의합니다. 마지막으로 Person
개체와 Student
개체를 만들고 해당 메서드를 호출했습니다. 🎜🎜다음은 class
를 사용하여 상속을 구현하는 예입니다. 🎜rrreee🎜위 예에서는 constructor
에서 Person
클래스를 정의합니다. > name
및 age
속성이 메소드에서 초기화되고 sayHi
메소드에서 인사말이 출력됩니다. 그런 다음 extends
키워드를 사용하여 Student
클래스를 만들고 super
키워드를 사용하여 Person
클래스를 호출했습니다. code>constructor 메소드는 name
및 age
속성을 초기화하고 major
속성을 추가합니다. 마지막으로 학생의 전공을 출력하기 위해 sayMajor
메소드를 정의합니다. 마지막으로 Person
개체와 Student
개체를 만들고 해당 메서드를 호출했습니다. 🎜🎜결론: 🎜🎜JavaScript에서 OOP는 객체, 생성자, 프로토타입 및 클래스를 사용하여 코드를 더 잘 구성하고 중복을 줄이는 매우 중요한 개념입니다. 상속은 프로토타입과 클래스를 통해 이루어질 수 있습니다. ES6부터 JavaScript는 객체 정의를 위한 더 간단하고 이해하기 쉬운 구문을 제공하는 class
키워드를 도입했습니다. 가능할 때마다 OOP 코드 작성에 대한 올바른 접근 방식을 선택하는 것이 중요합니다. 이는 프로젝트 개발 및 유지 관리에 상당한 이점을 제공하기 때문입니다. 🎜위 내용은 자바스크립트에서 oop를 작성하는 방법의 상세 내용입니다. 자세한 내용은 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)

뜨거운 주제











이 기사에서는 Data Fetching 및 기능 구성 요소의 DOM 조작과 같은 부작용을 관리하기위한 후크 인 React의 useEffect에 대해 설명합니다. 메모리 누출과 같은 문제를 방지하기 위해 사용법, 일반적인 부작용 및 정리를 설명합니다.

게으른로드는 필요할 때까지 컨텐츠로드를 지연시켜 초기로드 시간과 서버로드를 줄임으로써 웹 성능 및 사용자 경험을 향상시킵니다.

이 기사는 가상 Dom 트리를 비교하여 DOM을 효율적으로 업데이트하는 React의 조정 알고리즘을 설명합니다. 성능 이점, 최적화 기술 및 사용자 경험에 미치는 영향에 대해 설명합니다. 문자 수 : 159

JavaScript의 고차 기능은 추상화, 공통 패턴 및 최적화 기술을 통해 코드 간접성, 재사용 성, 모듈성 및 성능을 향상시킵니다.

이 기사는 다중 연계 기능을 단일 연계 함수 시퀀스로 변환하는 기술 인 JavaScript의 카레에 대해 논의합니다. Currying의 구현, 부분 응용 프로그램 및 실제 용도와 같은 혜택, 코드 읽기 향상을 탐색합니다.

이 기사는 REACT의 USECONTEXT를 설명하며, 이는 PROP 시추를 피함으로써 상태 관리를 단순화합니다. 중앙 집중식 상태 및 성능 개선과 같은 렌더링을 통해 성능 향상과 같은 이점에 대해 논의합니다.

기사에서는 extentdefault () 메서드를 사용하여 이벤트 처리기의 기본 동작 방지, 향상된 사용자 경험과 같은 이점 및 접근성 문제와 같은 잠재적 문제에 대해 논의합니다.

기사는 Connect ()를 사용하여 React 구성 요소를 Redux Store에 연결하고 MapStateToprops, MapDispatchtoprops 및 성능 영향을 설명합니다.
