COMING SOON 🚀

접근성을 고려한, 컨텐츠를 가리는 방법

반응형 웹 강좌를 준비하면서, 웹 접근성 측면에서 display:none의 문제점을 지적?한 글을 읽었습니다.

즉, 반응형 웹에서 스크린 폭에 따라서 조건부로 보이거나, 또는 마우스 클릭을 해야  보여야 하는 경우, 많은 경우 display:none을 이용하는데, 웹 접근성에 문제가 있다는 것입니다.

 CSS 규칙

화면 표현 

접근성 

 visibility: hidden;

적용된 요소가 화면에 나오지는 않지만, 원래 차지하는 공간은 남습니다.

스크린 리더가 무시합니다. 

 display: none;

적용된 요소가 화면에 나오지 않고, 공간도 없습니다.

스크린 리더가 무시합니다.

 height: 0; with: 0; overflow: hidden;

차지하는 공간이 없어지고 적용된 요소도 화면에 나오지 않습니다. 

스크린 리더가 무시합니다.

 text-indent: -999em;

적용된 요소가 화면에 보이지 않는 좌측으로 사라지지만, 링크에 포커스가 잡힐 수 있는 등 예측하지 못한 결과가 나올 수 있습니다. 

스크린 리더가 접근할 수 있으나, 이 방법은 텍스트와 인라인 요소에만 적용 가능합니다.

position: absolute; left: -999em;

적용된 요소가 화면에 보이지 않는 좌측 으로 사라지고, 공간도 차지하지 않습니다.

스크린 리더가 접근할 수 있습니다.


결국, position: absolute; left: -999em; 으로 가리는 것이 웹 접근성을 고려한다면 가장 적절한 방법이라고 합니다.

하지만, 직접 CSS를 적용하는 경우는 가능하지만, jQuery의 많은 화면 관련 기능들은 display:none 을 내부적으로 사용하고 있기에 이를 위한 별도의 조치가 필요하다고 합니다. 아래는 #myButton과 #myText 를 찾아서 적절한 클래스 (이경우 asseccibly-hidden, 즉 위의 position:absolute; left: -999em)로 적용하는 것입니다.

(function(){
  var $button = $('#myButton'),
      $text   = $('#myText'),
      visible = true;
  $button.click(function(){
    if ( visible ) {
      $text.slideUp('fast',function(){
        $text.addClass('accessibly-hidden')
             .slideDown(0);
      });
    } else {
      $text.slideUp(0,function(){
        $text.removeClass('accessibly-hidden')
             .slideDown('fast');
      });
    }
    visible = ! visible;
  });
})();

출처: Aaron Gustafson, Now You Can Me, A List Apart, 2011
|

댓글 4개

화면에서 안보이게 가려야 한다면.. 마찬가지로 스크린리더로도 읽혀지지 않아야 하지 않나요?
디자인측면에서 가려야 하는 경우와, 내용 측면에서 가려야 하는 경우가 다른것 같습니다.
무조건 display:none; 가 적절치 못하다고 표현한 제 의견 부분은 잘못된 것 같네요...
지적 감사합니다. :-)
좋은정보 감사합니다.
디자인적으로 보이지 말아야할 부분은 display:none; 으로 처리했었는데
이젠 다른방법으로 처리해 두어야겠네요^^
댓글을 작성하시려면 로그인이 필요합니다.

프로그램

+
제목 글쓴이 날짜 조회
13년 전 조회 2,539
13년 전 조회 3,784
13년 전 조회 2,889
13년 전 조회 1,866
13년 전 조회 3,566
13년 전 조회 3,262
13년 전 조회 2,036
13년 전 조회 1,926
13년 전 조회 4,476
13년 전 조회 2,865
13년 전 조회 1,857
13년 전 조회 1,770
13년 전 조회 9,391
13년 전 조회 5,916
13년 전 조회 9,067
13년 전 조회 2,007
13년 전 조회 2,652
13년 전 조회 3,086
13년 전 조회 2,494
13년 전 조회 4,011
13년 전 조회 2,254
13년 전 조회 2,398
13년 전 조회 1,852
13년 전 조회 2,458
13년 전 조회 2,589
13년 전 조회 1.4만
13년 전 조회 2,376
13년 전 조회 5,893
13년 전 조회 2,859
13년 전 조회 1,928
13년 전 조회 2,252
13년 전 조회 5,042
13년 전 조회 2,187
13년 전 조회 5,836
13년 전 조회 1,917
13년 전 조회 2,113
13년 전 조회 2,456
13년 전 조회 1만
13년 전 조회 2,728
13년 전 조회 3,836
13년 전 조회 2,955
13년 전 조회 3,159
13년 전 조회 3,290
13년 전 조회 2,282
13년 전 조회 2,487
13년 전 조회 1.9만
13년 전 조회 3,636
13년 전 조회 5,633
13년 전 조회 2,921
13년 전 조회 3,397
13년 전 조회 3,358
13년 전 조회 1.7만
13년 전 조회 2,281
13년 전 조회 2,183
13년 전 조회 1,953
13년 전 조회 2,907
13년 전 조회 4,461
13년 전 조회 4,618
13년 전 조회 3,432
13년 전 조회 6,874
13년 전 조회 4,081
13년 전 조회 7,249
13년 전 조회 2,908
13년 전 조회 2.2만
13년 전 조회 2,173
13년 전 조회 2,681
13년 전 조회 1.8만
13년 전 조회 3,954
13년 전 조회 2,279
13년 전 조회 4,975
13년 전 조회 2,449
13년 전 조회 2,605
13년 전 조회 2,040
13년 전 조회 3,794
13년 전 조회 2,796
13년 전 조회 1,957
13년 전 조회 2,125
13년 전 조회 8,695
13년 전 조회 3,591
13년 전 조회 2,219
13년 전 조회 2,498
13년 전 조회 4,101
13년 전 조회 2,292
13년 전 조회 2.1만
13년 전 조회 4,162
13년 전 조회 3,962
13년 전 조회 6,050
13년 전 조회 3,214
13년 전 조회 2,061
13년 전 조회 2,241
13년 전 조회 1.7만
13년 전 조회 2,042
13년 전 조회 3,385
13년 전 조회 2,936
13년 전 조회 2,529
13년 전 조회 2,395
13년 전 조회 2,547
13년 전 조회 2.5만
13년 전 조회 3,793
13년 전 조회 3만