-
데이터 타입 - 객체지향 | 생활코딩Javascript/ECMAScript 2009 (ES5) 2020. 2. 11. 21:47반응형
[출처 : https://opentutorials.org]
원시 데이터 타입(primitive type)
데이터 타입이란 데이터의 형태를 의미한다. 데이터 타입은 크게 두가지로 구분할 수 있다. 객체와 객체가 아닌 것.
ㆍ숫자 ㆍ문자열 ㆍ불리언(true/false) ㆍnull ㆍundefined
객체가 아닌 데이터 타입을 원시(기본) 데이터 타입이라고 한다. 그 외의 모든 데이터 타입들은 객체다.
레퍼 객체
var str = "coding"; // str = new String("coding") ⑵ 자바스크립트는 임시로 해당 객체를 만들고 사용이 끝나면 제거 console.log(str.length); // 6 ⑴ 원시 데이터 타입과 관련된 어떤 작업을 하려고 할 때 console.log(str.charAt(0)); // "c"
문자열은 분명히 프로퍼티와 메소드가 있다. 그렇다면 객체다. 그런데 왜 문자열이 객체가 아니라고 할까?
그것은 내부적으로 문자열이 원시 데이터 타입이고 문자열과 관련된 어떤 작업을 하려고 할 때⑴ 자바스크립트는 임시로 문자열 객체를 만들고 사용이 끝나면 제거⑵하기 때문이다.
이러한 처리는 내부적으로 일어난다. 그렇기 때문에 몰라도 된다. 하지만 원시 데이터 타입과 객체는 좀 다른 동작 방법을 가지고 있기 때문에 이들을 분별하는 것은 결국엔 필요하다.
var str = 'coding'; str.prop = 'everybody'; console.log(str.prop); // undefined
str.prop를 하는 순간에 자바스크립트 내부적으로 String 객체가 만들어진다. prop 프로퍼티는 이 객체에 저장되고 이 객체는 곧 제거 된다. 그렇기 때문에 prop라는 속성이 저장된 객체는 존재하지 않게된다. 이러한 특징은 일반적인 객체의 동작 방법과는 다르다.
하지만 문자열과 관련해서 필요한 기능성을 객체지향적으로 제공해야 하는 필요 또한 있기 때문에 원시 데이터 형을 객체처럼 다룰 수 있도록 하기 위한 객체를 자바스크립트는 제공하고 있는데 그것이 레퍼객체(wrapper object)다.
원시 데이터 타입에 맞는 레퍼 객체는 다음과 같다.
ㆍ숫자 - Number ㆍ문자열 - String ㆍ불리언(true/false) - Boolean null과 undefined - 존재하지 않음
반응형'Javascript > ECMAScript 2009 (ES5)' 카테고리의 다른 글
객체 복사하기(얕은·깊은) | ddalpange (0) 2020.02.26 참조 - 객체지향 | 생활코딩 (0) 2020.02.11 Object - 객체지향 | 생활코딩 (0) 2020.02.11 표준 내장 객체의 확장 - 객체지향 | 생활코딩 (0) 2020.02.10 prototype - 객체지향 | 생활코딩 (0) 2020.02.09