JavaScript : event listener & constructor

hosik kim·2022년 10월 5일
0

JavaScript

목록 보기
2/17
post-thumbnail

지난 정리글에 this의 의미를 정리를 하자면
1. 일반 함수에서 쓰는 window
2. 오브젝트 내의 함수(메소드)에서 쓰면 함수를 동작시키는 오브젝트
가 출력된다고 정리했다.

3. constructor 안에서 쓰면 constructor로 새로 생성되는 오브젝트

자바스크립트에서 오브젝트를 비슷한걸 여러개 만들고 싶을 경우
오브젝트를 복사하는게 아니라 constructor라는걸 만들어서 사용한다.
쉽게 말하면 constructor는 오브젝트 복사해서 생서해주는 기계다.
기계를 어떻게 만드는지 알아보자.

function 기계(){
	this.이름 = 'Kim';
}

함수 문법을 이요해서 만든 후, 안에 this.생략을 추가해주면된다.
여기서의 this는 기계로부터 새로 생성될 오브젝트들을 의미한다.

그럼 this.이름 = 'Kim' 이건 무슨 뜻일까?
새로 생성되는 오브젝트의 이름 key값에 'Kim'이라는 value를 집어넣으라는 뜻이다.

참고로 알아두면좋은 기계에서 오브젝트 뽑는 법

function 기계(){
	this.이름 = 'Kim'
}
var 오브젝트 = new 기계();

이렇게 new 키워드를 이용하면 새로운 오브젝트를 꺼낼 수 있다.
그리고 새로운 오브젝트는 {이름:'Kim'}이라는 값을 가지고 있다
(this라는 키워드 덕분에)

4. eventlistener 안에서 쓰는 this는 e.currentTarget이라는 의미

document.getElementById('버튼').addEventListener('click', fucntion(e){
	console.log(this)                                               
})

여기서 this를 소환하면 이것은 바로 e.currentTarget이라는 뜻과 똑같은 의미이다.
e.currentTarget은 지금 이벤트가 동작하는 곳을 뜻한다.
매우 간단히 설명하면 지금 addEventListener 부착된 HTML 요소를 뜻한다고 보면된다.
의심되면 e.currentTarget, this, document.getElementById('버튼') 세개를 각각 출력해보면된다.
이게 this의 마지막 뜻이다.

case 1. 이벤트리스너 안에서 콜백함수를 쓴다면 this는?

아래와 같은 코드를 쓴다고 가정해보자

document.getElementById('버튼').addEventListener('click', function(e){
  var 어레이 = [1,2,3];
  어레이.forEach(function(){
    console.log(this)
  });
});

이벤트리스너 안에서 forEach()라는 반복문을 사용했다.
forEach() 반복문을 사용할 땐 안에 fucntion(){} 콜백함수를 집어넣어서 사용하게 되어있다.
(콜백함수는 그냥 함수 안에 파라미터역할로 들어가는 함수를 뜻한다.)

Q.위의 코드에서 this를 출력하면 무엇이 나올까?

A. 4번뜻에 의하면 eventlistener 안에서 쓴 건 아니다.
eventlistener내부는 맞지만 그 안에서 function을 하나 더 만났기 때문에 의미가 변한다.
3번뜻에 의하면 constructor는 아니다.
this의 1번이나 2번뜻이 맞다.
저렇게 쌩으로 있는 콜백함수는 그냥 일반함수랑 똑같기 때문에 window가 출력된다.

case 2. 오브젝트 안에서 콜백함수를 쓴다면 this는?

아래와 같은 코드를 쓴다고 가정해보자

var 오브젝트 = {
	이름들 : ['김', '이', '박'];
  	함수 : fucntion() {
    	오브젝트.이름들.forEach(fucntion(){
        	console.log(this)                 
        });
    }
}

오브젝트라는 오브젝트 안에 이름들, 함수라는 자료를 각각 저장했다.
함수라는 자료 안에 forEach 반복문을 돌렸는데,

Q.위의 코드에서 this를 출력하면 무엇이 나올까?

A. forEach() 안에 있는 함수에 this가 들어가있다.
근데 이 함수는 특별한 역할을 하는 함수가 아니다.
이것 또한 일반 함수일 뿐이다. 그렇기 때문에 이것도 window이다.

그래서 this값은 fucntion을 만날 때마다 바뀔 수 있기 때문에
내가 원하는 this를 쓰기 힘든 경우가 있다.
그럴 땐 함수를 arrow function으로 바꾸면된다.

var 오브젝트 = {
  이름들 : ['김', '이', '박'];
  함수 : function(){
      오브젝트.이름들.forEach(() => {
        console.log(this)
      });
  }
}

자바스크립트 ES6 문법 중,
fucntion () {} 대신 쓸 수 있는 () => {} 이라는 arrow function 문법이 있다.
똑같이 함수를 만드는 문법이다.
이걸 쓰면 함수 내부의 this값을 새로 바꿔주지 않기 때문에 this를 사용하실 때 유용하다.

profile
안되면 될 때까지👌

0개의 댓글