업데이트:

블로그 퍼블리싱을 진행/수정하면서 WAI-ARIA를 많이 사용했었는데, 일부 잘못 알고 있어서 틀리게 사용했었던 것들을 풀어보면서 나름의 고찰(?)을 해보려고 한다.

aria-label은 텍스트 콘텐츠와 공존하지 않는다.

예시를 들어보겠음.

1
2
3
<button type="button" aria-label="닫기">
    <span aria-hidden="true">X</span>
</button>

닫기 버튼에 대한 시각적인 텍스트를 aria-hidden 속성으로 접근성 API에서 노출 안되게 한다음, aria-label 속성으로 적절한 레이블을 제공했으니 문제 없을 거다..는 잘못된 생각이었다.

1
<button type="button" aria-label="닫기">X</button>

올바른 마크업 예시로, aria-label은 요소의 텍스트 콘텐츠를 대체하므로 X 라는 텍스트 콘텐츠는 무시된다. 보조 기기에서 읽게되는 위 button 요소의 이름은 “닫기 버튼”이 된다.


또 하나, 내가 잘못 사용했었던 예시를 들어보겠음.

1
<a href="">나님의 일상 카테고리 <span aria-label="포스트 개수">(10)</span></a>

보조 기기가 낭독할 때 “나님의 일상 카테고리 포스트 개수”로 읽어준다. 올바른 레이블을 제공하려면 다음과 같은 방법을 적용할 수 있다.

1
2
3
4
5
<a href="">나님의 일상 카테고리 <span title="포스트 개수">(10)</span></a>

또는

<a href="">나님의 일상 카테고리 <span class="sr-only">포스트 개수</span>(10)</a>

title 속성이나 숨김 텍스트를 이용한 기법을 고려해볼 수 있겠다.

heading 요소는 부모 section/article 요소를 자동으로 참조하지 않는다.

1
2
3
4
<section>
    <h2>제목</h2>
    <p>내용</p>
</section>

위와 같은 마크업을 보조 기기가 읽을 때, “제목 영역”이라고 읽어줄 거라고 생각했었다.

section 요소에 role="region", article 요소에는 role="article" 속성이 기본값으로 적용되어 있긴 하나, 그렇다고 해서 heading 요소가 부모 section/article 요소를 자동으로 참조하지는 않는다.

1
2
3
4
<section aria-labelledby="title">
    <h2 id="title">제목</h2>
    <p>내용</p> <!-- 설명을 참조할 땐 aria-describedby 속성을 사용할 수 있으며, 나중에 다뤄보겠음. -->
</section>

aria-labelledby 속성으로 요소와 요소 간 연결을 해주어야 내가 바라던 결과가 나오게 된다. 스크린리더 NVDA 기준으로 웹페이지 상 랜드마크 영역으로 이동하는 D 키를 누르면, 쉽게 테스트해볼 수 있음.

1
2
3
4
5
<section aria-labelledby="title">
    <h2 id="title">제목 1</h2>
    <h2>제목 2</h2>
    <h2>제목 3</h2>
</section>

해당 속성을 사용하면 좋은 예시 또 하나,

브라우저가 접근 가능한 이름을 계산할 때, 가장 높은 우선 순위를 가지게 해주는 이점을 이용해서, 여러 제목이 존재할 때 사용해주면 보조 기기 사용자에게 좋은 퍼포먼스를 가져다 줄 수 있다.

참고 링크