Javascript/ECMAScript 2009 (ES5)
-
참조 - 객체지향 | 생활코딩Javascript/ECMAScript 2009 (ES5) 2020. 2. 11. 22:43
[출처 : https://opentutorials.org] 복제 전자화된 시스템의 가장 중요한 특징은 복제다. 현실의 사물과 다르게 전자화된 시스템 위의 데이터를 복제 하는데는 비용이 거의 들지 않는다. 바로 이러한 특징이 소프트웨어를 기존의 산업과 구분하는 가장 큰 특징일 것이다. 프로그래밍에서 복제가 무엇인가를 살펴보자. var a = 1; // 변수에 담겨진 값은 원시 데이터 타입 var b = a; b = 2 console.log(a); // 1 값을 변경한 것은 변수 b이기 때문에 변수 a에 담겨있는 값은 그대로이다. 변수 b의 값에 변수 a의 값이 복제된 것이다. 참조 var a = {"id":1}; // 변수에 담겨진 값은 참조 데이터 타입 var b = a; b.id = 2; console..
-
데이터 타입 - 객체지향 | 생활코딩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.char..
-
Object - 객체지향 | 생활코딩Javascript/ECMAScript 2009 (ES5) 2020. 2. 11. 01:07
[출처 : https://opentutorials.org] Object Object 객체는 객체의 가장 기본적인 형태를 가지고 있는 객체이다. 다시 말해서 아무것도 상속받지 않는 순수한 객체다. 자바스크립트에서는 값을 저장하는 기본적인 단위로 Object를 사용한다. (Object : 모든 객체가 상속하는 조상 객체) 동시에 자바스크립트의 모든 객체는 Object 객체를 상속 받는데, 그런 이유로 모든 객체는 Object 객체의 프로퍼티를 가지고 있다. Object API (Object가 가진 메소드) # Object.메소드() : Object 자신만 쓸 수 있음. (함수객체에 있는 메소드) // Object.keys() var pesron = {"name":"agal","age":20,"city":"s..
-
표준 내장 객체의 확장 - 객체지향 | 생활코딩Javascript/ECMAScript 2009 (ES5) 2020. 2. 10. 18:30
[출처 : https://opentutorials.org] 표준 내장 객체의 확장 표준 내장 객체(Standard Built-in Object)는 자바스크립트가 기본적으로 가지고 있는 객체들을 의미한다. 내장 객체가 중요한 이유는 프로그래밍을 하는데 기본적으로 필요한 도구들이기 때문에다. 결국 프로그래밍이라는 것은 언어와 호스트 환경에 제공하는 기능들을 통해서 새로운 소프트웨어를 만들어내는 것이기 때문에 내장 객체에 대한 이해는 프로그래밍의 기본이라고 할 수 있다. 자바스크립트 언어는 아래와 같은 내장 객체를 가지고 있다. ㆍObject ㆍFunction ㆍArray ㆍString ㆍBoolean ㆍNumber ㆍMath ㆍDate ㆍRegExp + 자바스크립트가 동작하는 호스트 환경이 제공하는 API ..
-
prototype - 객체지향 | 생활코딩Javascript/ECMAScript 2009 (ES5) 2020. 2. 9. 22:03
[출처 : https://opentutorials.org] Prototype prototype이란 무엇인가? 한국어로는 원형정도로 번역되는 prototype은 말 그대로 객체의 원형이라고 할 수 있다. 함수는 객체다. 그러므로 생성자로 사용될 함수도 객체다. 객체는 프로퍼티를 가질 수 있는데 prototype이라는 프로퍼티는 그 용도가 약속되어 있는 특수한 프로퍼티다. prototype에 저장된 속성들은 생성자를 통해서 객체가 만들어질 때 그 객체에 연결된다. function Ultra(){}; Ultra.prototype.ultraProp = true; function Super(){}; Super.prototype = new Ultra(); function Sub(){}; Sub.prototype =..
-
상속 - 객체지향 | 생활코딩Javascript/ECMAScript 2009 (ES5) 2020. 2. 9. 15:46
[출처 : https://opentutorials.org] 상속(inheritance)이란? 객체는 연관된 로직들로 이루어진 작은 프로그램이라고 할 수 있다. 상속은 객체의 로직을 그대로 물려 받는 또 다른 객체를 만들 수 있는 기능을 의미한다. 기존의 로직을 수정하고 변경해서 파생된 새로운 객체를 만들 수 있게 해준다. 상속을 위한 기본적인 준비는 다음과 같다. function Gundam(code){ this.code = code; } Gundam.prototype.code=null; Gundam.prototype.introduce = function(){ return "This is "+name; } var first = new Gundam("RX-78-2") console.log(first.int..
-
this - 객체지향 | 생활코딩Javascript/ECMAScript 2009 (ES5) 2020. 2. 9. 14:52
[출처 : https://opentutorials.org] this this는 함수 내에서 함수 호출 맥락(context)를 의미한다. 맥락이라는 것은 상황에 따라서 달라진다는 의미인데 즉 함수를 어떻게 호출하느냐에 따라서 this가 가리키는 대상이 달라진다는 뜻이다. 함수와 객체의 관계가 느슨한 자바스크립트에서 this는 이 둘을 연결시켜주는 실질적인 연결점의 역할을 한다. 함수호출 함수를 호출했을 때 this는 전역객체인 window와 같다. function func() { if (this === window) { console.log ("this is window") } } func(); //this is window 메소드의 호출 객체의 소속인 메소드의 this는 그 객체를 가르킨다. var ob..
-
전역객체 - 객체지향 | 생활코딩Javascript/ECMAScript 2009 (ES5) 2020. 2. 8. 17:24
[출처 : https://opentutorials.org] 전역객체란? 전역객체(Global object)는 특수한 객체다. 모든 객체는 이 전역객체의 프로퍼티다. 모든 전역변수와 함수는 사실 window 객체의 프로퍼티다. 객체를 명시하지 않으면 암시적으로 window의 프로퍼티로 간주된다. var object = { 'func' : function(){ console.log("Hello") } } object.func(); // Hello window.object.func(); // Hello 전역객체 API ECMAScript에서는 전역객체의 API를 정의해두었다. 그 외의 API는 호스트 환경에서 필요에 따라서 추가로 정의하고 있다. 이를테면 웹브라우저 자바스크립트에서는 alert()이라는 전역객..