Last updated
Last updated
어떤 DOM 엘리먼트에 이벤트가 발생하면, Capture Phase
=> Target Phase
=> Bubbling Phase
순서로 실행된다
이벤트에 따라서 일부 지원되지 않는 phase들은 스킵될 수 있다.
event
객체의 target
프로퍼티를 통해 이벤트가 발생한 엘리먼트를 확인할 수 있으며, currentTarget
를 통해 이벤트가 등록된 엘리먼트를 확인할 수 있다
event.stopPropagation()
메소드를 통해 이벤트 전파를 막을 수 있다. 만약 Capture Phase
에서 이벤트 전파를 막으면 Bubbling Phase
에 트리거될 예정인 콜백 함수들은 호출되지 않는다.
만약 어떤 엘리먼트의 이벤트를 처리하는 핸들러가 여러개인 상황에서 해당 엘리먼트에 등록된 다른 핸들러들의 동작도 막고싶으면 event.stopImmediatePropagation()
메소드를 사용하면 된다.(어떤 엘리먼트에 핸들러가 여러개 등록되어 있을경우 핸들러가 등록된 순서대로 콜백함수가 호출된다)
event.preventDefault()
메소드를 호출하면 이벤트를 취소할 수는 있지만, 이벤트의 전파는 막지 못한다.
부모 노드를 탐색한다.
첫 번째 자식 노드를 탐색한다.
IE를 제외한 대부분의 브라우저들은 요소 사이의 공백 또는 줄바꿈 문자를 텍스트 노드로 취급하기 때문에 Element를 얻을려면 Node.firstElementChild를 사용 해야 한다.
마지막 번째 자식 노드를 탐색한다.
IE를 제외한 대부분의 브라우저들은 요소 사이의 공백 또는 줄바꿈 문자를 텍스트 노드로 취급하기 때문에 Element를 얻을려면 Node.lastElementChild를 사용 해야 한다.
자식 노드가 있는지 확인한다.
자식 노드의 컬렉션을 반환한다. 텍스트 요소를 포함한 모든 자식 요소를 반환한다.
자식 노드의 컬렉션을 반환한다. 자식 요소 중에서 Element type 요소만을 반환한다.
이전 형제 노드를 탐색한다. text node를 포함한 모든 형제 노드를 탐색한다.
다음 형제 노드를 탐색한다. text node를 포함한 모든 형제 노드를 탐색한다.
이전 형제 엘리먼트를 탐색한다.
다음 형제 엘리먼트를 탐색한다.
노드의 html tag Name을 반환한다(대문자)
노드의 type을 반환한다.
해당 노드의 텍스트 콘텐츠를 탐색한다.
해당 요소의 모든 자식 요소를 포함하는 모든 콘텐츠를 하나의 문자열로 취득할 수 있다. 이 문자열은 마크업을 포함한다.
지정한 어트리뷰트를 가지고 있는지 검사한다.
해당 어트리뷰트의 값을 취득한다.
해당 어트리뷰트와 값을 설정한다.
해당 어트리뷰트를 제거한다.
innerHTML 프로퍼티를 사용하지 않고 새로운 콘텐츠를 추가할 수 있는 방법은 DOM을 직접 조작하는 것이다. 이 방법은 다음의 수순에 따라 진행한다.
요소 노드 생성: createElement() 메소드를 사용하여 새로운 요소 노드를 생성한다. createElement() 메소드의 인자로 태그 이름을 전달한다.
텍스트 노드 생성: createTextNode() 메소드를 사용하여 새로운 텍스트 노드를 생성한다. 경우에 따라 생략될 수 있지만 생략하는 경우, 콘텐츠가 비어 있는 요소가 된다.
생성된 요소를 DOM에 추가: appendChild() 메소드를 사용하여 생성된 노드를 DOM tree에 추가한다. 또는 removeChild() 메소드를 사용하여 DOM tree에서 노드를 삭제할 수도 있다.
인자로 전달한 텍스트를 HTML로 파싱하고 그 결과로 생성된 노드를 DOM 트리의 지정된 위치에 삽입한다. 첫번째 인자는 삽입 위치, 두번째 인자는 삽입할 요소를 표현한 문자열이다. 첫번째 인자로 올 수 있는 값은 아래와 같다.
‘beforebegin’: Node의 앞에 삽입한다.
‘afterbegin’: Node 내부의 맨 처음에 삽입한다.
‘beforeend’: Node 내부의 맨 뒤에 삽입한다.(appendChild)
‘afterend’: Node의 뒤에 삽입한다.