eventListner의 callback 함수 안에서 this를 사용하면 this는 eventListner가 부착된 element를 가리킨다.
하지만 callback 함수 안의 event인자를 사용해 event.target은 event를 trigger시킨 element를 가리키므로 둘은 다를 수 있다.
/* Delete Button */
const div = document.createElement("div");
const span = document.createElement("span");
span.innerText = "✕";
div.appendChild(span);
div.setAttribute("id", "delete-btn");
td2.appendChild(div);
td2.style.display = "flex";
td2.style.justifyContent = "space-between";
/* Do Delete */
const deleteBtns = document.querySelectorAll("#delete-btn");
console.log(deleteBtns);
deleteBtns.forEach((btn) => {
btn.addEventListener("click", deleteContent);
function deleteContent(event) {
console.log(event.target);
console.log(this);
}
anonymous function에서 this를 사용하면 현재 노드를 가리키지만
arrow function에서 사용하면 root object인 window를 가리킨다.
const items = document.querySelectorAll("li"); // 모든 항목 가져오기
for (let item of items) {
item.addEventListener("click", function () {
// 항목 클릭했을 때 실행할 함수
console.log(this);
this.parentNode.removeChild(this); // 부모 노드에서 삭제
});
}
for (let item of items) {
item.addEventListener("click", () => {
// 항목 클릭했을 때 실행할 함수
console.log(this);
this.parentNode.removeChild(this); // 부모 노드에서 삭제
});
}
'Language > Javascript' 카테고리의 다른 글
비동기 처리 (2) - Promise (0) | 2024.02.13 |
---|---|
비동기 처리 (1) - Callback (1) | 2024.02.13 |
append, appenChild와 remove, removeChild (0) | 2024.01.26 |
forEach와 for...in, for ...of (0) | 2024.01.23 |
isNaN과 Number.isNaN (0) | 2024.01.23 |