HTML 스타일 가이드

우리의 접근성 모범 사례도 참조하세요.

의미론적 요소

의미론적 요소는 HTML 태그로, 단순한 외형이 아닌 데이터에 의미적 의미를 제공합니다. 예를 들어:

의미적 태그를 사용하는 것이 좋지만, 의도가 태그의 의미와 정확히 일치할 때에만 사용하세요. 각 태그의 의미에 대한 설명은 MDN 문서를 참조하세요.

<!-- bad - div 대신 의미적 태그를 사용할 수 있습니다. -->
<div class="...">
  <p>
    <!-- bad - 이것이 "strong"이 의미하는 바가 아닙니다. -->
    Simply visit your <strong>Settings</strong> to say hello to the world.
  </p>
  <div class="...">...</div>
</div>

<!-- good - 정확하게 사용된 의미적 클래스를 선호합니다 -->
<section class="...">
  <p>
    Simply visit your <span class="gl-font-bold">Settings</span> to say hello to the world.
  </p>
  <footer class="...">...</footer>
</section>

버튼

버튼 유형

버튼 태그는 W3C HTML 명세에 따라 type 속성이 필요합니다.

// bad
<button></button>

// good
<button type="button"></button>

링크

새 탭 열기

임의로 링크를 새 탭에서 열기는 권장되지 않으므로 target="_blank"를 링크에 추가할 때 Pajamas 링크 가이드라인를 참조하세요.

a 태그에 target="_blank"를 사용할 때, rel="noopener noreferrer" 속성도 추가해야 합니다. 이는 JitBit 문서화된 보안 취약점을 방지합니다.

gl-link를 사용할 때는 target="_blank"를 사용하면 자동으로 링크에 rel="noopener noreferrer"를 추가하므로 충분합니다.

// bad
<a href="url" target="_blank"></a>

// good
<a href="url" target="_blank" rel="noopener noreferrer"></a>

// good
<gl-link href="url" target="_blank"></gl-link>

가짜 링크

가짜 링크를 사용하지 마세요. 링크가 JavaScript 클릭 이벤트 처리기를 호출하는 경우에는 button 태그를 사용하는 것이 더 의미론적입니다.

// bad
<a class="js-do-something" href="#"></a>

// good
<button class="js-do-something" type="button"></button>