--- title: Alerts slug: Web/Accessibility/ARIA/forms/alerts tags: - ARIA - Forms - Web - 접근성 translation_of: Web/Accessibility/ARIA/forms/alerts ---
엑세스 가능한 오류 검사를 포함하고 싶은 폼, 예를 들어 콘택트 폼이 있습니다. 자주 있는 문제점으로는 Email이 유효하지 않거나, 이름 필드에 성이나 이름이 포함되지 않은 것이 있습니다.
우선 aria-required
기술을 읽지 않았다면 먼저 읽어주세요. 여기서는 그것의 확장된 내용을 다룹니다.
여기에 샘플 폼이 있습니다:
<form method="post" action="post.php"> <fieldset> <legend>Please enter your contact details</legend> <label for="name">Your name (required):</label> <input name="name" id="name" aria-required="true"/> <br /> <label for="email">E-Mail address (required):</label> <input name="email" id="email" aria-required="true"/> <br /> <label for="website">Website (optional):</label> <input name="website" id="website"/> </fieldset> <label for="message">Please enter your message (required):</label> <br /> <textarea name="message" id="message" rows="5" cols="80" aria-required="true"></textarea> <br /> <input type="submit" name="submit" value="Send message"/> <input type="reset" name="reset" value="Reset form"/> </form>
폼 유효성 검사는 여러 단계로 구성됩니다. :
aria-invalid
속성에 “true
” 값이 주어질 것입니다.alert
’ function을 사용하는 대신 아림을 위해 간단한 WAI-ARIA 위젯을 사용할 것입니다. 이것은 사용자에게 에러를 알려주지만, Javascript의 기본 ‘alert
’ function의 “onblur
”로 인해 발생하는 포커스 손실 없이 계속해서 폼을 수정할 수 있게 해줍니다. 아래의 예제는 “head
” 의 닫는 태그를 삽입하는 Javascript 코드입니다.:
<script type="application/javascript"> function removeOldAlert() { var oldAlert = document.getElementById("alert"); if (oldAlert){ document.body.removeChild(oldAlert); } } function addAlert(aMsg) { removeOldAlert(); var newAlert = document.createElement("div"); newAlert.setAttribute("role", "alert"); newAlert.setAttribute("id", "alert"); var msg = document.createTextNode(aMsg); newAlert.appendChild(msg); document.body.appendChild(newAlert); } function checkValidity(aID, aSearchTerm, aMsg) { var elem = document.getElementById(aID); var invalid = (elem.value.indexOf(aSearchTerm) < 0); if (invalid) { elem.setAttribute("aria-invalid", "true"); addAlert(aMsg); } else { elem.setAttribute("aria-invalid", "false"); removeOldAlert(); } } </script>
checkValidity
함수Javascript에서 폼 유효성 검사에 사용되는 기본 메소드는 checkValidity
함수입니다. 이 메소드는 세 개의 파라미터를 가집니다: 유효성 검사를 할 input
의 ID, 유효성을 확인하기 위해 검색할 검색어, alert에 삽입할 에러 메시지입니다.
유효성을 확인하기 위해, 이 함수는 input
의 값 indexOf
가 -1보다 큰지 확인합니다. 검색어를 찾을 수 없을 때 -1
혹은 그보다 작은 값을 반환합니다.
만약에 값이 유효하지 않다면 이 함수는 2가지 작업을 수행합니다.
aria-invalid
속성을 “true
”로 설정합니다. 이 속성은 사용자에게 여기에 유효하지 않은 값이 있다는 것을 알립니다. addAlert
함수를 호출하여 제공된 에러 메시지와 함께 alert을 추가합니다. 검색어가 발견되면 aria-invalid
속성은 “false
”로 재설정됩니다. 또한 남아있는 모든 alert가 제거됩니다.
addAlert
함수이 함수는 일단 오래된 alert을 제거합니다. 이 함수는 간단합니다. : id가 “alert
”인 요소를 찾고, 발견되면 document object model.에서 해당 요소를 제거합니다.
다음으로 함수는 alert 테스트를 저장할 div
요소를 만듭니다. 그 div
요소는 “alert
”이라는 ID를 갖습니다. 그리고 “alert”이라는 role을 갖습니다. 이름에 "aria"가 없지만 사실은 ARIA에서 만들어진 것입니다. role이 간소화를 위해 단순히 HTML로 이식된 XHTML Role Attribute Module에 기반하기 때문입니다.
텍스트가 div
요소에 추가되고 div
요소는 문서에 추가됩니다.
이 div
요소가 나타나면 Firefox는 보조기기에 "alert" 이벤트를 발생시킵니다. 대부분의 스크린 리더는 자동으로 그것을 주워서 읽습니다. 이건 암호 저장 여부를 묻는 Firefox의 알림 표시 줄과 비슷합니다. 방금 만든 alert에는 버튼이 없으므로 단순히 무엇이 문제인지만을 알려줍니다.
onblur
” 이벤트 수정하기이제 남은 것은 이벤트 핸들러를 추가하는 것뿐입니다. 우리는 Email과 이름에 대한 두개의 인풋을 다음과 같이 변경해야합니다. :
<input name="name" id="name" aria-required="true" onblur="checkValidity('name', ' ', 'Invalid name entered!');"/> <br /> <input name="email" id="email" aria-required="true" onblur="checkValidity('email', '@', 'Invalid e-mail address');"/>
예제 테스트하기
만약 Firefox 3 와 현재 지원되는 스크린 리더를 사용하고 있다면 다음을 시도해보세요.:
두 경우 모두 필드로 포커스가 돌아가면 스크린 리더는 해당 필드가 유효하지 않음을 알려주어야 합니다. JAWS 9는 이것을 지원하지만, JAWS 8는 지원하지 않습니다. 그렇기때문에 이것은 스크린 리더 버전에 따라서 동작하지 않을 수 있습니다.
(required)
” 를 넣고 일부 input에 aria-required
속성을 넣었나요?