HTML API

이 시리즈의 소개에서는 'HTML 요소는 문서 개체 모델을 구성하는 노드입니다.'라고 설명합니다. 요소 노드의 유형을 설명했습니다. 이 섹션에서는 이러한 노드를 쿼리할 수 있는 요소 API를 설명합니다.

DOM 및 AOM

DOM은 문서에 액세스하고 문서를 조작하기 위한 API입니다. DOM은 문서의 모든 노드의 트리입니다. 일부 노드에는 하위 노드가 있을 수 있고 다른 노드에는 없을 수 있습니다. 트리에는 요소와 속성, 텍스트 노드가 포함됩니다.

요소와 텍스트 노드를 보여주는 MLW 노드 트리

브라우저 도구는 위와 같은 트리 시각화를 제공하지 않지만 요소 검사기에서 노드를 볼 수 있습니다.

DOM/ARIA

브라우저 개발자 도구에서 검사할 수 있는 트리 표현은 접근성 트리입니다. AOM은 DOM을 기반으로 합니다. 마찬가지로 접근성 트리에는 모든 마크업 요소, 속성, 텍스트 노드를 나타내는 객체가 포함되어 있습니다.

AOM의 예

HTML 요소 API

DOM의 중간 글자는 'object'입니다. 대부분의 객체 지향 프로그래밍 소개 클래스의 person 또는 car 객체 예와 마찬가지로 문서 트리의 모든 노드는 JavaScript로 조작할 수 있는 객체입니다.

브라우저는 기본적으로 지원되는 메서드, 이벤트, 속성 쿼리 및 업데이트를 제공하는 여러 API를 제공합니다. 요소 노드에는 요소에 설정된 모든 속성에 관한 정보가 포함됩니다. HTML 인터페이스를 사용하여 요소의 속성에 관한 정보에 액세스할 수 있습니다. 예를 들어 HTMLImageElement.alt를 사용하여 모든 이미지의 alt 속성을 가져올 수 있습니다.

let allImages = document.querySelectorAll('img');
allImages.forEach((imageInstance) => {
  console.log(imageInstance.alt);
});

HTML 인터페이스는 요소의 속성에 액세스하는 것 이상을 제공합니다. 훨씬 더 많은 정보에 액세스할 수 있습니다. 읽기 전용 HTMLElement.offsetHeight를 찾아 레이아웃을 기준으로 페이지의 각 섹션 높이를 가져올 수 있습니다.

let allSections = document.querySelectorAll('section');
allSections.forEach((sectionInstance) => {
  console.log(sectionInstance.offsetHeight);
});

사용자가 기기 방향을 변경하거나 표시 영역의 너비를 변경하면 각 <section>의 높이가 변경되고 DOM 속성이 자동으로 업데이트됩니다.

HTML 인터페이스 API는 속성 값에 액세스하는 것으로 제한되지 않습니다. DOM은 UI의 현재 상태에 대한 유용한 정보를 제공합니다. HTML API는 이러한 모든 정보에 액세스할 수 있습니다. 뷰가 현재 재생 중인 동영상의 길이와 동영상 (또는 오디오) 재생이 완료된 경우 각각 HTMLMediaElement.duration, HTMLMediaElement.currentTime, HTMLMediaElement.ended를 사용하여 액세스할 수 있습니다.

사용 가능한 요소 인터페이스

이 시리즈에서 지금까지 다루었거나 아직 다루지 않은 대부분의 HTML 요소(일부 섹션 요소 제외)에는 연결된 DOM 인터페이스가 있습니다. 모든 요소의 기본 인터페이스 이름은 적절하게 Element입니다. HTMLElement는 Element에서 상속받으며 모든 HTML 요소별 인터페이스는 이를 상속받습니다. 일부 요소별 인터페이스는 유사한 여러 요소로 구현됩니다.

인터페이스는 다음과 같습니다.

이름 지정 규칙은 'HTML' 다음에 단어마다 첫 글자를 대문자로 쓰는 카멜 표기법으로 요소 또는 요소 그룹을 지정한 후 '요소'를 지정하지만 요소 또는 요소 그룹 부분은 정확한 패턴을 따르지 않습니다. 걱정하지 마세요. 암기할 필요는 없습니다. 필요한 경우 찾아볼 수 있도록 이러한 페이지가 존재한다는 것을 알고 있는 것이 중요합니다.

요소 모음이 있는 경우 컬렉션 인터페이스도 있습니다. 예를 들어 HTMLCollection.namedItem() 메서드는 id 또는 name 속성이 매개변수와 일치하는 컬렉션의 첫 번째 요소를 반환하거나 일치하는 요소가 없는 경우 null을 반환합니다.

30개가 넘는 요소(예: <address>, <article>, <section>, <nav>, <header>, <footer>, <aside>, <hgroup>)에는 HTMLElement 외의 연결된 DOM 인터페이스가 없습니다. 지원 중단되지 않고 전역이 아닌 속성을 지원하지 않는 많은 요소에는 HTMLPElement (<p> 요소) 및 HTMLUnknownElement(<😃> 또는 정의되지 않은 다른 요소)와 같은 요소별 인터페이스가 있지만 이러한 인터페이스는 HTMLElement에서 상속받은 속성과 메서드 외에 추가 속성이나 메서드를 구현하지 않으며 위에 나열되지 않습니다.

중복 API 메서드 및 속성

상속받는 인터페이스와 인터페이스의 메서드 또는 속성 이름이 동일한 경우 상속 메서드 또는 속성이 상속된 메서드 또는 속성을 덮어씁니다. 즉, 상위 메서드와 속성이 하위 메서드와 속성을 재정의합니다. HTML 요소 APIaltoffsetHeight 속성에 각각 imageInstance.altsectionInstance.offsetHeight를 사용하여 액세스하면 코드에서 액세스 중인 API를 식별하지 못했습니다. 일반적으로 이 두 가지 예와 마찬가지로 이는 문제가 아닙니다.

하지만 중복으로 인해 문제가 발생할 수 있는 경우도 있습니다. 예를 들어 HTMLCollection.length는 읽기 전용이지만 상속 인터페이스인 HTMLOptionsCollection에는 읽기 및 쓰기 액세스 권한이 있는 길이 속성 (<select>options 속성에서만 반환됨)이 있습니다. HTMLOptionsCollection를 사용하여 수집 크기를 설정할 수 있습니다.

기타 인터페이스

DOM 노드의 브랜치 위치를 조작할 수 있는 추가 인터페이스가 있습니다. addEventListener()removeEventListener()를 제공하는 EventTarget 인터페이스는 NodeWindow 인터페이스에서 상속됩니다. 반대로 Element, Document, DocumentFragment (맞춤 요소에서 살펴봄) 인터페이스는 Node에서 상속받고 HTMLElement 인터페이스는 Element에서 상속받습니다.

node 인터페이스

모든 유형의 DOM 노드는 Node를 기반으로 하는 인터페이스로 표현되며, 이 인터페이스는 요소가 DOM 트리와 관련된 정보와 메서드를 제공합니다. Node 인터페이스를 사용하면 노드 트리에 노드를 쿼리하고 추가할 수 있습니다.

Douglas Crockford의 유명한 'DOM 탐색' 함수는 노드의 firstChildnextSibling 속성을 사용합니다.

const walk_the_DOM = function walk(node, callback) {
  callback(node);
  node = node.firstChild;
  while (node) {
    walk(node, callback);
    node = node.nextSibling;
  }
};

맞춤 요소를 정의할 때 노드의 appendChild()cloneNode() 메서드를 사용했습니다. Node 인터페이스는 DOM을 쿼리하고 조작하는 데 유용한 여러 속성과 메서드를 제공합니다.

customElements.define('star-rating',
  class extends HTMLElement {
    constructor() {
      super(); // Always call super first in constructor
      const starRating = document.getElementById('star-rating-template').content;
      const shadowRoot = this.attachShadow({
        mode: 'open'
      });
      shadowRoot.appendChild(starRating.cloneNode(true));
    }
  });

attachShadow() 메서드는 Element 인터페이스의 메서드입니다. 문서의 기본 DOM 트리와 별도로 렌더링되는 Shadow DOM APIshadowRoot 인터페이스도 있습니다.

DocumentHTMLDocument 인터페이스

Document 인터페이스는 Node에서 상속됩니다. 문서가 HTML, SVG, XML, MathML 등 무엇이든 브라우저에 로드된 웹페이지를 나타냅니다. Document 인터페이스는 HTMLDocument 인터페이스에서도 상속됩니다.

document를 사용하면 노드 유형에 빠르게 액세스하고 document.bodydocument.styleSheets와 같은 특정 요소 유형의 컬렉션을 만들 수 있습니다. HTMLDocument를 사용하면 Document.location, Document.lastModified, Document.Cookie와 같이 HTML 노드에 없는 문서와 관련된 정보에 액세스할 수 있습니다.

Drag and Drop APIFullScreen API를 비롯하여 문서 인터페이스를 통해 표시되는 기능을 기반으로 여러 API를 사용할 수 있습니다. 둘 다 Element에서 상속됩니다.

Window 인터페이스

Window 인터페이스에는 DOM을 조작하는 데 사용할 수 있는 DOM 외의 전역적으로 사용 가능한 항목이 포함되어 있습니다. Window는 MDN의 JavaScriptDOM 참조에 설명된 함수, 네임스페이스, 객체, 생성자를 제공합니다.

Window 인터페이스는 문서가 포함된 객체의 API입니다. 전역 window 객체는 스크립트가 실행되는 창입니다. 모든 브라우저 탭에는 자체 Window 객체가 포함되어 있습니다. Window 인터페이스는 전체 창 및 기기뿐만 아니라 탭의 콘텐츠도 쿼리할 수 있습니다. 예를 들어 resizeTo() 메서드를 사용하여 브라우저 창 크기를 조절할 수 있고 devicePixelRatio 속성을 통해 기기 디스플레이 픽셀에 액세스할 수 있습니다. 탭이 표시하는 DOM 트리 대신 콘텐츠가 있는 탭에 관한 정보에 액세스하는 경우 창이 찾고 있는 인터페이스일 가능성이 큽니다.

Web WorkersIndexedDB API를 비롯하여 Window 인터페이스를 통해 표시되는 기능을 기반으로 여러 API를 사용할 수 있습니다.

이해도 확인

HTML API에 관한 지식을 테스트합니다.

DOM의 O는 무엇을 의미하나요?

방향이 지정됩니다.
다시 시도하세요.
다음은 객체입니다
정답입니다.
외부
다시 시도하세요.

콘텐츠가 있는 탭에 대한 정보를 찾는 데 도움이 되는 인터페이스는 무엇인가요?

정답입니다.
문서
다시 시도하세요.
노드
다시 시도하세요.