전역객체
모든 객체는 전역객체의 프로퍼티입니다. window라는 전역객체의 프로퍼티입니다.
function func(){ var o = {'func':function(){
alert('Hello?'); alert('Hello?');
} }}
func(); o.func();
window.func(); window.o.func();
func();와 window.func();는 모두 실행 가능합니다. 모든 전역변수와 함수는 사실 window 객체의 프로퍼티다. 객체를 명시하지 않으면 암시적으로 window의 프로퍼티로 간주됩니다.
this
객체지향에 대한 시야를 높이기 위한 수업입니다.
This는 함수 내에서 함수의 호출 맥락을 의미합니다. 의미가 고정에 되어 있지 않고 가변적일 때 맥락을 사용합니다. 함수와 객체의 관계가 느슨한 자바스크립트에서 this는 둘을 연결시키는 연결점의 역할을 합니다. 함수내의 this 값은 window를 의미합니다.
메소드와 this
var o = {
func : function(){ //func 프로퍼티는 함수이기에 메소드입니다.
if(o === this){
document.write("o === this");
}
}
}
o.func();
객체 안에서 메소드를 호출하면 메소드가 소속되어있는 객체를 this로 접근할 수 있습니다.
func라는 함수가 객체에 소속되어 있지 않은 경우 this는 window라는 전역객체를 가리킵니다.
o.func() 호출 시 this는 o가 됩니다.
생성자와 this
생성자로 사용 될 때는 this값은 생성될 객체를 가리킵니다.
함수로 호출하면 함수 안의 this는 window를 가리킵니다.
var funcThis = null;
function Func(){
funcThis = this;
}
var o1 = Func();
if(funcThis === window){
document.write('window <br />'); //window
}
var o2 = new Func();
if(funcThis === o2){
document.write('o2 <br />'); //o2
}
생성자는 빈 객체를 만듭니다. 그리고 이 객체내에서 this는 만들어진 객체를 가르킵니다. 이것은 매우 중요한 사실이다. 생성자가 실행되기 전까지는 객체는 변수에도 할당될 수 없기 때문에 this가 아니면 객체에 대한 어떠한 작업을 할 수 없기 때문입니다.
객체로서의 함수
apply, call
마지막의 인자가 함수의 본문에 해당
Sum()이라는 함수 객체를 만든 것, 문법적으로 작성해 자바스크립트가 함수 객체를 만들어줍니다.
이를 함수 리터럴(Literal)이라고 합니다. 문법적으로 리터럴이라고 부릅니다.
함수가 가질 수 있는 프로퍼티 중 ecma에서 정의한 것이 apply, call입니다.
var o = {}
var p = {}
function func(){
switch(this){
case o:
document.write('o<br />');
break;
case p:
document.write('p<br />');
break;
case window:
document.write('window<br />');
break;
}
}
func(); //window
func.apply(o); //o
func.apply(p); //p 객체p를 의미
ecma의 표준 메소드인 apply()
객체의 포함되어 있는 것이 메소드, 다른 곳에 가지 못하고 고정되어 있습니다.
자바스크립트는 유연하다.
언어에서 함수는 일반적인 객체지향의 메소드보다 위상이 높다. 어떻게 호출하느냐에 따라 함수는 어떠한 객체에 종속되는 존재이기도 합니다. This는 어떤 맥락에서 어떤 의미를 갖는가를 알아야합니다. this는 소속되어 있는 객체를 의미합니다.
출처 : 생활코딩 강의
'프로그래밍 > JavaScript' 카테고리의 다른 글
자바스크립트 : 표준 내장 객체의 확장, Object (0) | 2017.11.23 |
---|---|
자바스크립트 : 상속(Inheritance)과 prototype (0) | 2017.11.22 |
자바스크립트 : 생성자와 new (2) | 2017.11.18 |
자바스크립트 : 객체지향프로그래밍(OOP : Object Oriented Programming) (0) | 2017.11.17 |
자바스크립트 : arguments, 함수의 호출 (0) | 2017.11.16 |