기본 콘텐츠로 건너뛰기

6월, 2023의 게시물 표시

dialog 태그

 개발을 하다보면, 기획 및 디자인에, 레이어 팝업을 사용하는 디자인이 꽤나 많다. 자 생각해보자. 그러면 우리 개발자들은 레이어 팝업을 만들기 위해서 개발을 엄청 해왔다. 하지만 말이다. 뭐 특정 라이브러리를 사용하지 않는 이상, 꽤나 귀찮은 일이다.  팝업을 만드는 경우에, 크롬, 엣지, 사파리 등등을 다 지원해야 하기때문에, css를 까닥 잘못했다가는 제대로 만들어지지 않는 경우가 있다.  그것 뿐인가? 포커스를 생각해보자. 일반사용자가 tab을 이용하여, 하단에 노출되어있는 엘리먼트에 접근을 하는 것을 막기 위하여, click및 focus를 막기 위한, inert속성을 적용 해야하며, 해당 팝업이 닫혔을 때, 포커스를 되돌려 주어야 한다. 스크롤 조작때문이라도, 이렇게 진행 하는 것이 맞다.  아주 귀찮은 일이며, 매 프로젝트 마다 해야한다. 이러한 귀찮음을 한번에 해결해 줄 dialog라는 태그가 있다! 당연하게도 ie는 안되니, polyfill을 찾아야 한다.  dialog  자 간단하게, 사용법 먼저 확인하자.  간단하게, HTMLDialogElement showModal, show, close 함수를 제공한다. 위에서 확인하면 알듯이, showModal은 전체화면을 덮으며, 최상위에 노출이 되고, show는 노출은 되나, 최상위는 아니다. showModal이후에 show를 호출하는 행위는 해서는 안된다.  close는 당연하게도 팝업을 닫는 행위를 진행한다.  close이벤트 와 cancel이벤트를 제공을 하며, cancel의 경우 esc를 눌렀을 때의 이벤트며, 해당 창을 닫으며, close 발생 시키기에, 해당 기능이 필요 없다면, preventDefault를 사용하면 된다.  form method="dialog"  우리가 팝업을 왜 쓰나? 알림용도로만 사용 하는가? 그렇지 않다. 사용자의 입력을 받을때에도 사용 한다.  그거 아는가? form에 method에 get, post만 알고 있을 것이다. 이제 dialog도 생

웹접근성 - 1 (장애소개)

 현재 특정 업체를 위하여, 웹 접근성 심사 기준을 통과 할 수 있도록, 퍼블리싱을 진행 중이다. 해당 퍼블리싱을 진행 중에, 필요했었던, 혹은 필요한 내용들을 진행 하고자 한다. 일단 장애에 대한 분류를 해보자. 시각장애     전맹  전맹인 경우, 센스리더 (nvda, talkback)등을 이용한 탐색을 진행 할 것이다.     저시력  저시력자의 경우 글자크기를 확대하거나 창을 확대하여 탐색을 진행 할 것이다.     색맹  색맹의 경우 일반적인 탐색은 가능하나, 색상 차이는 확인 할 수 없고 채도로만 컨텐츠 구분이 가능하다. 즉 색상을 고대비를 이용해야 한다. 청각장애  소리를 듣지 못하므로, 동영상을 볼 때, 자막만 사용 가능하다. 지체장애      상지장애  손을 사용할 수 없는 경우이다. 핀치 줌, 아웃 등 두 손가락 이상 사용 하는 액션을 불가능이라고 봐야 한다.      기타  움직임이 어려운 경우 이다. 즉, 어떠한 액션이 있었을 때, 즉각적인 반응을 할 수 없다. 언어장애  복잡한 용어는 이해가 불가능 하다. 약관과 같이 어려운 용어를 사용해야 할 때, 쉬운 용어로 변경 해주는 등 해당 내용이 필요 하다. 웹 개발자가 신경써야 하는 부분?  사실은 전부 신경 써야 하는 부분이다.  일단, 디자이너, 기획자, 개발자 이렇게 세명이 진행한다고 해보자.  시각장애 - 전맹 *  가장 다루기 까다로운 타입으로 전맹의 경우 센스리더를 이용하며, 센스리더를 이용 한다. 이 때, 주의 할 점은 해당 상황에 적절한 마크업을 해야 한다는 것이다.  div태그 를 이용하여, 버튼을 구현 하는 경우. 센스리더는 버튼으로 인식을 못하기에, button태그를 이용 하여 진행 해야 한다.  이 부분은 할말이 많으므로, 추가 컨텐츠에서 처리를 다루겠다.  시각장애 - 저시력 *  저시력 자의 경우 시스템 폰트를 키워서 사용 하게 된다. 해당 상황이 되더라도, UI가 깨지지 않도록 최대한 지원을 해주어야 한다.  또한, max-scale을 설정해서는 안된다. 저시력자의