패스트캠퍼스/자습
자바스크립트로 하는 자료구조와 알고리즘(6장) - 객체
sunnykim91
2019. 10. 24. 16:17
객체에 속성 추가하기
let javaScriptObject = {};
let testArray = [1,2,3,4];
javaScriptObject.array = testArray;
console.log(javaScriptObject);
javaScriptObject.title = 'Algo';
console.log(javaScriptObject);
프로토타입 활용 상속
function ExampleClass() {
this.name = "Javascript";
this.sayName = function() {
console.log(this.name);
}
}
let example1 = new ExampleClass();
example1.sayName();
.prototype을 활용하여 메소드를 동적으로 추가할 수 있다.
function ExampleClass() {
this.array = [1,2,3,4,5];
this.name = "javascript";
}
let example1 = new ExampleClass();
ExampleClass.prototype.sayName = function () {
console.log(this.name);
}
example1.sayName();
클래스의 함수들을 생성자에서 추가하거나 .prototype을 통해 추가할 수 있다.
생성자와 변수
해당 객체의 속성들을 다른 범위에서도 직접 접근이 가능하다.
function ExampleClass(name, size) {
this.name = name;
this.size = size;
}
let example1 = new ExampleClass("public", 5);
console.log(example1);
console.log(example1.name);
console.log(example1.size);
get, set 을 이용해서 접근을 제어 할 수 있다.
function ExampleClass(name, size) {
let privateName = name;
let privateSize = size;
this.getName = () => privateName;
this.setName = (name) => {privateName = name;};
this.getSize = () => privateSize;
this.setSize = (size) => {privateSize = size};
}
let example = new ExampleClass("ssss", 3);
example.setSize(12);
console.log(example.privateName); // 직접 접근할 수 없어서 undefined
console.log(example.getName());
console.log(example.size);
console.log(example.getSize());
function Animal(name, animalType) {
this.name = name;
this.animalType = animalType;
}
Animal.prototype.sayName = function() { // Animal클래스에 sayName 메소드 동적 추가
console.log(this.name);
}
Animal.prototype.sayAnimalType = function() { // Animal클래스에 sayAnimalType 메소드 동적 추가
console.log(this.animalType);
}
function Dog(name) { // // Dog라는 클래스 생성
Animal.call(this, name, "Dog"); // Animal함수를 호출
}
Dog.prototype = Object.create(Animal.prototype); // 새 객체를 만듬.
let myAnimal = new Animal("ditto", "pokemon");
myAnimal.sayName();
myAnimal.sayAnimalType();
let myDog = new Dog("candy", "dog");
myDog.sayName();
myDog.sayAnimalType();
반응형