이 기사에서는 JavaScript 생성자에 의한 객체 생성과 관련된 문제를 주로 소개하는 javascript에 대한 관련 지식을 제공합니다. 생성자(생성자)는 생성자 및 유형 함수라고도 하며 해당 기능은 객체 템플릿과 유사합니다. 인스턴스 객체는 동일한 속성과 동작 특성을 가지고 있지만 동일하지 않습니다. 모두에게 도움이 되기를 바랍니다.
[관련 추천 : javascript 동영상 튜토리얼, 웹 프론트엔드]
자바스크립트 생성자(Constructor)라고도 불리는 생성자, 타입함수로 그 기능은 비슷합니다. 객체 템플릿에 대한 생성자 함수는 인스턴스를 얼마든지 생성할 수 있습니다. 인스턴스 객체는 동일한 속성과 동작 특성을 가지지만 동일하지는 않습니다.
생성자를 사용하여 다양한 클래스의 개체를 만듭니다.
생성자는 일반적인 함수입니다. 생성 방법과 일반 함수 사이에는 차이가 없습니다. 생성자와 일반 함수의 차이점은 호출 방법의 차이입니다. 직접 생성자는 새 키워드를 사용하여
이 포인팅 문제3가지 형태의 포인팅 상황을 호출해야 합니다.생성자 인스턴스
nbsp;html> <meta> <meta> <meta> <title>Document</title> <script> //构造一个创建人的类 function Person(name , age , gender){ console.log('指向:',this); this.name = name; this.age = age ; this.gender = gender; this.sayName = function(){ console.log(this.name) } } //构造一个创建狗的类 function Dog(name , age ){ console.log('指向:',this); this.name = name; this.age = age ; this.sayHello = function(){ console.log('汪汪汪~~'); } } //创建一个人的实例 var per = new Person('苏凉',21,'男'); console.log(per); per.sayName(); //创建一个狗的实例 var dog = new Dog('旺财',5); console.log(dog); dog.sayHello(); </script>
실행 결과:
instanceof 키워드
instanceof를 사용하여 객체가 클래스의 인스턴스인지 확인하세요
구문:
console.log(dog instanceof Dog); //true console.log(dog instanceof Person); //false console.log(dog instanceof Object); //true
모든 객체는 Object의 자손입니다. object는 0object로 인스턴스 검사를 수행할 때 true를 반환합니다.
성능 최적화Person 생성자에는 각 개체에 대해 sayName 메서드가 추가됩니다.현재 우리 메서드는 생성자 내부, 즉 생성자가 실행될 때마다 생성됩니다. 새로운 sayName 메서드는 생성됩니다즉, 모든 인스턴스의 sayName은 고유합니다. 이것은 많은 메모리를 차지하며 새로 생성된 개체마다 새로운 메서드가 생성됩니다.
对象 instanceof 构造函数
Person 생성자 만들기
해결 방법: 새로 생성된 객체의 메소드를 다음과 같이 별도로 추출합니다.
nbsp;html> <meta> <meta> <meta> <title>Document</title> <script> //将新创建对象的方法单独提取出来 function sayName(){ console.log(this.name) } //构造一个创建人的类 function Person(name , age , gender){ console.log('指向:',this); this.name = name; this.age = age ; this.gender = gender; this.sayName = sayName; } var per = new Person('苏凉',21,'男'); var per1 = new Person('小红',18,'女'); console.log(per); per.sayName(); per1.sayName(); console.log(per.sayName == per1.sayName); //true </script>per의 sayName 메소드와 per1의 sayName 메소드가 동일한 것을 알 수 있습니다. 이는 다른 인스턴스를 생성할 때 새로운 sayName 메소드를 다시 생성하는 문제를 해결하여 메모리 사용량을 크게 줄입니다.
지식 확장
(1.) 생성자가 필요한 이유:
객체를 생성하는 처음 두 가지 방법은 한 번에 하나의 객체만 생성할 수 있기 때문입니다. (2.) 생성자란 무엇입니까?
생성자: 개체의 동일한 속성과 메서드 중 일부를 추상화하여 함수로 캡슐화합니다.
(3.)利用构造函数创建对象及使用方法
构造函数的函数名从第一个单词开始,每个单词的首写字母都要大写。
/ /4.在构造函数里面我们的属性和方法前面都必须加this关键字
//声明构造函数语法格式: function 构造函数名() { this.属性 = 值; this.方法 = function() {} } //调用构造函数语法格式: new 构造函数名();
以下是构造函数语法格式的案例:
【相关推荐:javascript视频教程、web前端】
위 내용은 JavaScript 생성자는 객체를 생성합니다(요약 공유)의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!