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>