Attributes

HTML 개요에서 속성에 대해 간단히 설명했습니다. 이제 자세히 살펴볼 시간입니다.

속성은 HTML을 강력하게 만드는 요소입니다. 속성은 여는 태그에 표시되는 공백으로 구분된 이름과 이름/값 쌍으로, 요소에 관한 정보와 기능을 제공합니다.

HTML 요소에 라벨이 지정된 시작 태그, 속성, 종료 태그

속성은 요소의 동작, 연결, 기능을 정의합니다. 일부 속성은 전역 속성입니다. 즉, 모든 요소의 시작 태그 내에 표시될 수 있습니다. 다른 속성은 일부 요소에만 적용되지만, 다른 속성은 요소별로 다르며 단일 요소에만 관련이 있습니다. HTML에서는 부울을 제외한 모든 속성과 어느 정도는 열거형 속성에 값이 필요합니다.

속성 값에 공백이나 특수문자가 포함된 경우 값을 따옴표로 묶어야 합니다. 따라서 가독성을 높이기 위해 항상 따옴표를 사용하는 것이 좋습니다.

HTML은 대소문자를 구분하지 않지만 일부 속성 값은 대소문자를 구분합니다. HTML 사양의 일부인 값은 대소문자를 구분하지 않습니다. 정의된 문자열 값(예: 클래스 및 ID 이름)은 대소문자를 구분합니다. HTML에서 속성 값이 대소문자를 구분하는 경우 CSS 및 JavaScript에서 속성 선택자의 일부로 사용될 때 대소문자를 구분합니다. 그렇지 않으면 대소문자를 구분하지 않습니다.

<!-- the type attribute is case insensitive: these are equivalent -->
<input type="text">
<input type="TeXt">

<!-- the id attribute is case sensitive: they are not equivalent -->
<div id="myId">
<div id="MyID">

부울 속성

불리언 속성이 있는 경우 항상 true입니다. 불리언 속성에는 autofocus, inert, checked, disabled, required, reversed, allowfullscreen, default, loop, autoplay, controls, muted, readonly, multiple,, selected가 포함됩니다. 이러한 속성 중 하나 이상이 있는 경우 요소가 사용 중지되거나, 필수 속성이 되거나, 읽기 전용 상태가 됩니다. 속성이 없으면 요소가 사용 중지되지 않습니다.

불리언 값은 생략되거나 빈 문자열로 설정되거나 속성의 이름일 수 있습니다. 하지만 값이 실제로 문자열 true로 설정될 필요는 없습니다. true, false, 😀를 비롯한 모든 값은 유효하지 않지만 true로 확인됩니다.

다음 세 태그는 동일합니다.

<input required>
<input required="">
<input required="required">

속성 값이 false인 경우 속성을 생략합니다. 속성이 true인 경우 속성을 포함하되 값은 제공하지 않습니다. 예를 들어 required="required"는 HTML에서 유효한 값이 아닙니다. 하지만 required는 불리언이므로 잘못된 값은 true로 확인됩니다. 하지만 잘못된 열거형 속성이 반드시 누락된 값과 동일한 값으로 확인되지는 않으므로, 어떤 속성이 부울인지 열거형인지 기억하고 잠재적으로 잘못된 값을 제공하는 것보다 값을 생략하는 습관을 들이는 것이 더 쉽습니다.

true와 false 간에 전환할 때는 값을 전환하는 대신 JavaScript로 속성을 모두 추가하고 삭제합니다.

const myMedia = document.getElementById("mediaFile");
myMedia.removeAttribute("muted");
myMedia.setAttribute("muted");

SVG와 같은 XML 언어에서는 부울 속성을 비롯한 모든 속성에 값을 포함해야 합니다.

열거형 속성

열거형 속성을 불리언 속성과 혼동하는 경우가 있습니다. 사전 정의된 유효한 값의 제한된 집합이 있는 HTML 속성입니다. 불리언 속성과 마찬가지로 속성이 있지만 값이 없는 경우 기본값이 있습니다. 예를 들어 <style contenteditable>를 포함하면 기본값은 <style contenteditable="true">입니다.

하지만 불리언 속성과 달리 속성을 생략한다고 해서 false가 되는 것은 아닙니다. 값이 누락된 속성이 있다고 해서 반드시 true가 아닙니다. 잘못된 값의 기본값이 null 문자열과 반드시 같지 않은 것도 아닙니다. 예를 계속해서 살펴보면 contenteditable은 누락되거나 잘못된 경우 기본값이 inherit이고 명시적으로 false로 설정할 수 있습니다.

기본값은 속성에 따라 다릅니다. 불리언 값과 달리 속성이 있는 경우 자동으로 'true'가 아닙니다. <style contenteditable="false">를 포함하면 요소를 수정할 수 없습니다. 값이 잘못된 경우(예: <style contenteditable="😀"> 또는 놀랍게도 <style contenteditable="contenteditable">) 값이 잘못되었으며 기본값은 inherit입니다.

열거형 속성이 있는 대부분의 경우 누락된 값과 잘못된 값은 동일합니다. 예를 들어 <input>type 속성이 누락되거나, 존재하지만 값이 없거나, 잘못된 값이 있는 경우 기본값은 text입니다. 이러한 동작은 일반적이지만 규칙은 아닙니다. 따라서 불리언 속성과 열거형 속성을 구분하는 것이 중요합니다. 가능하면 값을 잘못 이해하지 않도록 값을 생략하고 필요에 따라 값을 조회하세요.

전역 속성

전역 속성은 <head>의 요소를 비롯한 모든 HTML 요소에 설정할 수 있는 속성입니다. 30개가 넘는 글로벌 속성이 있습니다. 이 속성은 모두 이론적으로 HTML 요소에 추가할 수 있지만 일부 요소에 설정하면 일부 전역 속성은 영향을 미치지 않습니다. 예를 들어 <meta>hidden를 설정하면 메타 콘텐츠가 표시되지 않습니다.

id

전역 속성 id는 요소의 고유 식별자를 정의하는 데 사용됩니다. 다음과 같은 여러 가지 목적으로 사용됩니다. - 링크의 프래그먼트 식별자의 타겟 - 스크립팅을 위한 요소 식별 - 양식 요소를 라벨과 연결합니다. - 보조 기술에 라벨 또는 설명을 제공합니다. - CSS에서 (특수성이 높거나 속성 선택자로) 스타일 타겟팅

id 값은 공백이 없는 문자열입니다. 공백이 포함된 경우 문서가 끊어지지 않지만 HTML, CSS, JS에서 이스케이프 문자로 id를 타겟팅해야 합니다. 그 밖의 모든 문자는 유효합니다. id 값은 😀 또는 .class일 수 있지만 권장하지 않습니다. 현재와 미래의 나를 위해 프로그래밍을 더 쉽게 하려면 id의 첫 번째 문자를 문자로 만들고 ASCII 문자, 숫자, _, -만 사용하세요. id 값은 대소문자를 구분하므로 id 이름 지정 규칙을 마련한 후 이를 준수하는 것이 좋습니다.

id은 문서에 고유해야 합니다. id가 두 번 이상 사용되더라도 페이지 레이아웃은 중단되지 않지만 JavaScript, 링크, 요소 상호작용이 예상대로 작동하지 않을 수 있습니다.

탐색 메뉴에는 4개의 링크가 있습니다. 링크 요소는 나중에 다루겠지만 지금은 링크가 HTTP 기반 URL로 제한되지 않는다는 점에 유의하세요. 링크는 현재 문서 또는 다른 문서의 페이지 섹션에 대한 프래그먼트 식별자일 수 있습니다.

머신러닝 워크숍 사이트의 페이지 헤더에 있는 탐색 메뉴에는 다음과 같은 4개의 링크가 포함되어 있습니다.

href 속성은 링크를 활성화하면 사용자가 이동하는 하이퍼링크를 제공합니다. URL에 해시 기호 (#) 뒤에 문자열이 포함된 경우 이 문자열은 프래그먼트 식별자입니다. 이 문자열이 웹페이지의 요소의 id와 일치하면 프래그먼트는 해당 요소의 앵커 또는 북마크입니다. 브라우저가 앵커가 정의된 지점으로 스크롤합니다.

이 네 개의 링크는 id 속성으로 식별되는 페이지의 네 섹션을 가리킵니다. 사용자가 탐색 메뉴의 4개 링크 중 하나를 클릭하면 프래그먼트 식별자로 연결된 요소, 일치하는 ID에서 #를 뺀 값을 포함하는 요소가 스크롤되어 표시됩니다.

머신러닝 워크숍의 <main> 콘텐츠에는 ID가 있는 4개의 섹션이 있습니다. 사이트 방문자가 <nav>의 링크 중 하나를 클릭하면 해당 프래그먼트 식별자가 있는 섹션이 스크롤되어 표시됩니다. 마크업은 다음과 유사합니다.

<section id="reg">
  <h2>Machine Learning Workshop Tickets</h2>
</section>

<section id="about">
  <h2>What you'll learn</h2>
</section>

<section id="teachers">
  <h2>Your Instructors</h2>
  <h3>Hal 9000 <span>&amp;</span> EVE</h3>
</section>

<section id="feedback">
  <h2>What it's like to learn good and do other stuff good too</h2>
</section>

<nav> 링크의 프래그먼트 식별자를 비교해 보면 각각 <main><section>id와 일치하는 것을 알 수 있습니다. 브라우저에서 무료 '페이지 상단' 링크를 제공합니다. href="#top"(대소문자 구분 안 함) 또는 href="#"를 설정하면 사용자가 페이지 상단으로 스크롤됩니다.

href의 해시 기호 구분자는 프래그먼트 식별자의 일부가 아닙니다. 프래그먼트 식별자는 항상 URL의 마지막 부분이며 서버로 전송되지 않습니다.

CSS 선택 도구

CSS에서는 #feedback와 같은 ID 선택기를 사용하여 각 섹션을 타겟팅하거나, 특정성이 낮은 경우 대소문자를 구분하는 속성 선택기 [id="feedback"]를 사용할 수 있습니다.

스크립트 작성

MLW.com에는 마우스 사용자만 이용할 수 있는 이스터 에그가 있습니다. 전등 스위치를 클릭하면 페이지가 켜졌다 꺼졌다를 반복합니다.

전등 스위치 이미지의 마크업은 다음과 같습니다. html <img src="svg/switch2.svg" id="switch" alt="light switch" class="light" /> id 속성은 getElementById() 메서드의 매개변수로 사용되며 # 접두사를 사용하면 querySelector()querySelectorAll() 메서드의 매개변수의 일부로 사용할 수 있습니다.

const switchViaID = document.getElementById("switch");
const switchViaSelector = document.querySelector("#switch");

다음 JavaScript 함수는 이 기능을 사용하여 id 속성으로 요소를 타겟팅합니다.

<script>
  /* switch is a reserved word in js, so we us onoff instead */
  const onoff = document.getElementById('switch');
  onoff.addEventListener('click', function(){
    document.body.classList.toggle('black');
  });
</script>

<label>

HTML <label> 요소에는 연결된 양식 컨트롤의 id를 값으로 사용하는 for 속성이 있습니다. 모든 양식 컨트롤에 id를 포함하고 각 컨트롤을 라벨의 for 속성과 페어링하여 명시적 라벨을 만들면 모든 양식 컨트롤에 연결된 라벨이 생성됩니다.

각 라벨은 정확히 하나의 양식 컨트롤과 연결될 수 있지만 양식 컨트롤에는 연결된 라벨이 두 개 이상 있을 수 있습니다.

양식 컨트롤이 <label> 열기 태그와 닫기 태그 사이에 중첩된 경우 forid 속성은 필요하지 않습니다. 이를 '암시적' 라벨이라고 합니다. 라벨을 사용하면 모든 사용자가 각 양식 컨트롤의 용도를 알 수 있습니다.

<label>
  Send me a reminder <input type="number" name="min"> before the workshop resumes
</label>.

forid 간의 연결을 통해 보조 기술 사용자는 정보를 사용할 수 있습니다. 또한 라벨의 아무 곳이나 클릭하면 연결된 요소에 포커스가 설정되어 컨트롤의 클릭 영역이 확장됩니다. 이는 기민성 문제가 있어 마우스 사용이 정확하지 않은 사용자에게만 도움이 되는 것이 아니라 라디오 버튼보다 손가락이 넓은 모든 휴대기기 사용자에게도 도움이 됩니다.

이 코드 예시에서 가짜 퀴즈의 가짜 다섯 번째 질문은 객관식 단일 정답 문제입니다. 각 양식 컨트롤에는 고유한 id가 있는 명시적 라벨이 있습니다. 실수로 ID가 중복되지 않도록 ID 값은 질문 번호와 값의 조합입니다.

라디오 버튼을 포함할 때 라벨은 라디오 버튼의 값을 설명하므로 동일한 이름의 버튼을 모두 <fieldset>에 포함하고 <legend>는 전체 세트의 라벨 또는 질문이 됩니다.

기타 접근성 사용

접근성과 사용성에서 id의 사용은 라벨로 제한되지 않습니다. 텍스트 소개에서는 <section>aria-labelledby 값으로 <h2>id를 참조하여 <section>를 지역 랜드마크로 변환하여 액세스 가능한 이름을 제공했습니다.

<section id="about" aria-labelledby="about_heading">
<h2 id="about_heading">What you'll learn</h2>

접근성을 보장하는 데 사용할 수 있는 aria-* 상태 및 속성은 50개가 넘습니다. aria-labelledby, aria-describedby, aria-details, aria-owns는 값으로 공백으로 구분된 id 참조 목록을 사용합니다. 현재 포커스가 있는 하위 요소를 식별하는 aria-activedescendant는 포커스가 있는 단일 요소의 단일 id 참조를 값으로 사용합니다 (한 번에 하나의 요소에만 포커스를 설정할 수 있음).

class

class 속성은 CSS (및 JavaScript)로 요소를 타겟팅하는 추가적인 방법을 제공하지만 HTML에서는 다른 목적으로 사용되지 않습니다 (프레임워크 및 구성요소 라이브러리에서 사용할 수는 있음). class 속성은 요소의 대소문자를 구분하는 클래스의 공백으로 구분된 목록을 값으로 취합니다.

건전한 시맨틱 구조를 구축하면 게재위치와 기능을 기반으로 요소를 타겟팅할 수 있습니다. 건전한 구조를 사용하면 하위 요소 선택기, 관계 선택기, 속성 선택기를 사용할 수 있습니다. 이 섹션에서 속성에 관해 자세히 알아볼 때 동일한 속성 또는 속성 값을 가진 요소의 스타일을 지정하는 방법을 고려하세요. 클래스 속성을 사용해서는 안 된다는 것이 아니라 대부분의 개발자가 클래스 속성을 사용할 필요가 없는 경우가 많다는 사실을 깨닫지 못한다는 의미입니다.

지금까지 MLW는 클래스를 사용하지 않았습니다. 단일 클래스 이름 없이 사이트를 실행할 수 있나요? 두고 보겠습니다.

style

style 속성을 사용하면 속성이 설정된 단일 요소에 적용되는 인라인 스타일을 적용할 수 있습니다. style 속성은 CSS 속성 값 쌍을 값으로 사용하며, 값의 문법은 CSS 스타일 블록의 콘텐츠와 동일합니다. CSS와 마찬가지로 속성 뒤에는 콜론이 오고 각 선언은 세미콜론으로 끝나며 세미콜론은 값 뒤에 옵니다.

스타일은 속성이 설정된 요소에만 적용되며, 중첩된 요소 또는 <style> 블록 또는 스타일 시트의 다른 스타일 선언에서 재정의하지 않는 한 상위 요소에서 상속된 속성 값을 상속합니다. 이 값은 해당 요소에만 적용된 단일 스타일 블록의 콘텐츠와 동일한 내용으로 구성되므로 생성된 콘텐츠에 사용하거나 키프레임 애니메이션을 만들거나 다른 at-rule을 적용할 수 없습니다.

style는 실제로 전역 속성이지만 사용하지 않는 것이 좋습니다. 대신 별도의 파일에서 스타일을 정의하세요. 하지만 style 속성은 테스트 목적으로 빠른 스타일 지정을 사용 설정하는 등 개발 중에 유용할 수 있습니다. 그런 다음 '해결 방법' 스타일을 가져와 연결된 CSS 파일에 붙여넣습니다.

tabindex

tabindex 속성을 모든 요소에 추가하여 포커스를 받을 수 있도록 할 수 있습니다. tabindex 값은 탭 순서에 추가되는지 여부와 선택적으로 기본이 아닌 탭 순서에 추가되는지 여부를 정의합니다.

tabindex 속성은 정수를 값으로 사용합니다. 음수 값 (관례적으로 -1 사용)은 JavaScript를 통해 포커스를 받을 수 있는 요소를 만들지만 요소를 탭 시퀀스에 추가하지는 않습니다. tabindex 값이 0이면 요소에 포커스를 설정할 수 있고 탭을 통해 도달할 수 있게 되어 소스 코드 순서로 페이지의 기본 탭 순서에 요소가 추가됩니다. 값이 1 이상이면 요소가 우선순위가 지정된 포커스 시퀀스에 포함되며 권장되지 않습니다.

이 페이지에는 <button> 역할을 하는 <share-action> 맞춤 요소를 사용하는 공유 기능이 있습니다. 0의 tabindex는 맞춤 요소를 키보드 기본 탭 순서에 추가하기 위해 포함됩니다.

<share-action authors="@estellevw" data-action="click" data-category="web.dev" data-icon="share" data-label="share, twitter" role="button" tabindex="0">
  <svg aria-label="share" role="img" xmlns="http://www.w3.org/2000/svg">
    <use href="#shareIcon" />
  </svg>
  <span>Share</span>
</share-action>

buttonrole는 스크린 리더 사용자에게 이 요소가 버튼처럼 작동해야 한다고 알려줍니다. JavaScript는 clickkeydown 이벤트를 모두 처리하고 Enter 및 스페이스바 키 누르기를 처리하는 등 버튼 기능 약속이 유지되도록 하는 데 사용됩니다.

양식 컨트롤, 링크, 버튼, 수정 가능한 콘텐츠 요소는 포커스를 받을 수 있습니다. 키보드 사용자가 탭 키를 누르면 포커스가 tabindex="0"가 설정된 것처럼 다음 포커스 가능한 요소로 이동합니다. 다른 요소는 기본적으로 포커스를 받을 수 없습니다. 이러한 요소에 tabindex 속성을 추가하면 포커스를 받지 못하는 경우에도 포커스를 받을 수 있습니다.

문서에 tabindex1 이상인 요소가 포함된 경우 별도의 탭 시퀀스에 포함됩니다. Codepen에서 볼 수 있듯이 탭은 소스 순서대로 일반 시퀀스를 거치기 전에 가장 낮은 값에서 가장 높은 값 순으로 별도의 시퀀스에서 시작됩니다.

탭 순서를 변경하면 사용자 환경이 매우 나빠질 수 있습니다. 따라서 키보드와 스크린 리더와 같은 보조 기술을 사용하여 콘텐츠를 탐색하기가 어렵습니다. 또한 개발자가 관리하고 유지하기 어렵습니다. 초점이 중요합니다. 초점과 초점 순서를 다루는 전체 모듈이 있습니다.

role

role 속성WHATWG HTML 사양이 아닌 ARIA 사양의 일부입니다. role 속성은 콘텐츠에 시맨틱 의미를 제공하는 데 사용할 수 있으므로 스크린 리더가 사이트 사용자에게 객체의 예상 사용자 상호작용을 알릴 수 있습니다.

콤보박스, 메뉴바, 탭 목록, 트리 그리드와 같이 네이티브 HTML 등가 항목이 없는 몇 가지 일반적인 UI 위젯이 있습니다. 예를 들어 탭 디자인 패턴을 만들 때 tab, tablist, tabpanel 역할을 사용할 수 있습니다. 사용자 인터페이스를 실제로 볼 수 있는 사용자는 관련 탭을 클릭하여 위젯을 탐색하고 다양한 패널을 표시하는 방법을 경험을 통해 배웠습니다. 버튼 그룹을 사용하여 여러 패널을 표시할 때 <button role="tab">와 함께 tab 역할을 포함하면 스크린 리더 사용자는 현재 포커스가 있는 <button>가 일반적인 버튼과 같은 기능을 구현하는 대신 관련 패널을 뷰로 전환할 수 있음을 알 수 있습니다.

role 속성은 브라우저 동작을 변경하거나 키보드 또는 포인터 기기 상호작용을 변경하지 않습니다. <span>role="button"를 추가해도 <button>로 변환되지 않습니다. 따라서 시맨틱 HTML 요소를 의도한 용도로 사용하는 것이 좋습니다. 하지만 올바른 요소를 사용할 수 없는 경우 role 속성을 사용하면 시맨틱이 아닌 요소가 시맨틱 요소의 역할로 개조되었을 때 스크린 리더 사용자에게 알릴 수 있습니다.

contenteditable

contenteditable 속성이 true로 설정된 요소는 수정 가능하고 포커스를 받을 수 있으며 tabindex="0"가 설정된 것처럼 탭 순서에 추가됩니다. Contenteditabletruefalse 값을 지원하는 열거형 속성으로, 속성이 없거나 잘못된 값을 보유한 경우 기본값은 inherit입니다.

다음 세 개의 시작 태그는 동일합니다.

<style contenteditable>
<style contenteditable="">
<style contenteditable="true">

<style contenteditable="false">를 포함하면 요소를 수정할 수 없습니다(<textarea>처럼 기본적으로 수정 가능한 요소는 예외). 값이 잘못된 경우(예: <style contenteditable="😀"> 또는 <style contenteditable="contenteditable">) 기본값은 inherit입니다.

상태 간에 전환하려면 HTMLElement.isContentEditable 읽기 전용 속성의 값을 쿼리합니다.

const editor = document.getElementById("myElement");
if(editor.contentEditable) {
  editor.setAttribute("contenteditable", "false");
} else {
  editor.setAttribute("contenteditable", "");
}

또는 editor.contentEditabletrue, false 또는 inherit로 설정하여 이 속성을 지정할 수 있습니다.

전역 속성은 <style> 요소를 포함한 모든 요소에 적용할 수 있습니다. 속성과 약간의 CSS를 사용하여 실시간 CSS 편집기를 만들 수 있습니다.

<style contenteditable>
style {
  color: inherit;
  display:block;
  border: 1px solid;
  font: inherit;
  font-family: monospace;
  padding:1em;
  border-radius: 1em;
  white-space: pre;
}
</style>

stylecolorinherit 이외의 속성으로 변경해 보세요. 그런 다음 stylep 선택기로 변경해 보세요. 디스플레이 속성을 삭제하면 스타일 블록이 사라집니다.

커스텀 속성

HTML 글로벌 속성의 일부만 살펴봤습니다. 하나 또는 제한된 요소 집합에만 적용되는 속성도 더 많이 있습니다. 수백 개의 속성이 정의되어 있더라도 사양에 없는 속성이 필요할 수 있습니다. HTML을 사용하면 됩니다.

data- 접두사를 추가하여 원하는 맞춤 속성을 만들 수 있습니다. 속성 이름은 data-로 시작하고 xml로 시작하지 않으며 콜론 (:)을 포함하지 않는 소문자 문자열로 지정할 수 있습니다.

HTML은 관대하여 지원되지 않는 속성(data로 시작하지 않음)을 만들거나 맞춤 속성을 xml로 시작하거나 :를 포함하더라도 중단되지 않습니다. 하지만 data-로 시작하는 유효한 맞춤 속성을 만드는 것이 좋습니다. 맞춤 데이터 속성을 사용하면 실수로 기존 속성 이름을 사용하지 않는지 알 수 있습니다. 맞춤 데이터 속성은 미래에 대비할 수 있습니다.

브라우저는 특정 data- 접두사 속성에 기본 동작을 구현하지 않지만 맞춤 속성을 반복하는 내장 데이터 세트 API가 있습니다. 맞춤 속성은 JavaScript를 통해 애플리케이션별 정보를 전달하는 데 매우 유용합니다. data-name 형식의 요소에 맞춤 속성을 추가하고 해당 요소에서 dataset[name]를 사용하여 DOM을 통해 이러한 속성에 액세스합니다.

<blockquote data-machine-learning="workshop"
  data-first-name="Blendan" data-last-name="Smooth"
  data-formerly="Margarita Maker" data-aspiring="Load Balancer"
  data-year-graduated="2022">
  HAL and EVE could teach a fan to blow hot air.
</blockquote>

전체 속성 이름을 사용하여 getAttribute()를 사용하거나 더 간단한 dataset 속성을 활용할 수 있습니다.

el.dataset["machineLearning"]; // workshop
e.dataset.machineLearning; // workshop

dataset 속성은 각 요소의 data- 속성의 DOMStringMap 객체를 반환합니다. <blockquote>에는 여러 맞춤 속성이 있습니다. 데이터 세트 속성은 이름과 값에 액세스하기 위해 이러한 맞춤 속성이 무엇인지 알 필요가 없음을 의미합니다.

for (let key in el.dataset) {
  customObject[key] = el.dataset[key];
}

이 도움말의 속성은 전역 속성입니다. 즉, 모든 HTML 요소에 적용할 수 있지만 모든 속성이 요소에 영향을 미치는 것은 아닙니다. 다음으로 링크를 자세히 살펴보면서 소개 이미지에서 다루지 않은 두 가지 속성(targethref)과 다른 여러 요소별 속성을 살펴봅니다.

이해도 확인

속성에 대한 지식을 테스트합니다.

id는 문서에서 고유해야 합니다.

거짓

올바르게 형성된 맞춤 속성을 선택합니다.

data:birthday
data-birthday
birthday