작은 팁이지만 혹시 비슷한 문제로 고민하시는 분 계시면 도움이 되길 바랍니다.
우선 이 글에서, 자바스크립트를 끈 하위 브라우저에서는 활용할 수 없는 placeholder.js 는 논외로 함을 밝혀드립니다.
결과물 미리보기

자바스크립트를 켰을 때 자바스크립트를 껐을 때
웹 접근성 가이드라인에서는 자바스크립트만으로 기능을 이용할 수 있어서는 안된다고 명시하고 있습니다.
이제 제가 올릴 팁은 '기능'이라기보다는 '비주얼'에 가깝지만, 비약하자면 기능과 같은 맥락에 포함된다고 볼 수도 있을 것입니다.
placeholder 를 사용할 수 없는 브라우저에 대한 대안은 두가지가 있습니다.
- 위에서 언급한 placeholder.js 를 사용하는 방법
- label 의 위치를 css 로 제어하고, js 로 효과를 주는 방법
- input 의 background 로 제어하는 방법
다른 방법이 더 있다면 알려주세요. 꾸벅
다음 이미지는 2번의 방법으로 만든 로그인폼입니다.

회원아이디, 패스워드는 label 입니다.
position:absolute;top:~px;left:~px;블라블라블라~ 처럼 스타일을 준 것이죠.
그리고 jquery 로 인풋박스에 focus 되었을 때, 해당 인풋박스와 연결되는 label 을 일시적으로 보이지 않게 하는 방법으로 구현합니다.
html<fieldset><input type="hidden" name="url" value="<?=$outlogin_url?>"><label for="ol_id" id="ol_idlabel">회원아이디</label><input type="text" id="ol_id" name="mb_id" maxlength="20" required title="회원아이디"><label for="ol_pw" id="ol_pwlabel">패스워드</label><input type="password" id="ol_pw" name="mb_password" maxlength="20" required title="패스워드"><input type="submit" id="ol_submit" value="로그인"><ul><li id="ol_auto"><input type="checkbox" id="auto_login" name="auto_login" value="1"><label for="auto_login" id="auto_login_label">자동로그인</label></li><li><a href="<?=$g4['bbs_url']?>/register.php">회원가입</a></li><li><a href="<?=$g4['bbs_url']?>/password_lost.php" id="ol_password_lost">정보찾기</a></li></ul></fieldset>css#ol_id{display:block;margin-bottom:3px;padding:0 5px;width:185px;height:22px;border:1px solid #d7d7d7;background:#fff;line-height:1.6em}#ol_idlabel {z-index:2;position:absolute;top:23px;left:20px;color:#696969}#ol_pw {padding:0 5px;width:121px;height:22px;border:1px solid #d7d7d7;background:#fff;line-height:1.6em}#ol_pwlabel {z-index:2;position:absolute;top:50px;left:20px;color:#696969}js$(document).ready(function(){$omi = $('#ol_id'); //아이디 입력창$omp = $('#ol_pw'); //패스워드 입력창$omi_label = $('#ol_idlabel'); //아이디 레이블$omp_label = $('#ol_pwlabel'); //패스워드 레이블$omi.focus(function() { //아이디 입력창 포커스$omi_label.css('visibility','hidden');});$omp.focus(function() { //패스워드 입력창 포커스$omp_label.css('visibility','hidden');});$omi.blur(function() { //아이디 입력창 포커스 해제$this = $(this);if($this.attr('id') == "ol_mb_id" && $this.attr('value') == "") $omi_label.css('visibility','visible');});$omp.blur(function() { //패스워드 입력창 포커스 해제$this = $(this);if($this.attr('id') == "ol_mb_pw" && $this.attr('value') == "") $omp_label.css('visibility','visible');});});

아이디 인풋박스에 포커스되었을 때 이미지입니다.
이 모든 작동은 자바스크립트를 사용할 수 있는 환경에서 이루어집니다.
그런데 위에서 언급한 바와 같이 우리는 자바스크립트가 꺼진 상태도 고려를 해야 합니다.

자바스크립트를 끈 상태에서 아이디를 입력해본 모습입니다.
바로 위의 이미지에서는 회원아이디라는 label 이 깔끔하게 사라졌지만 이 이미지에서는 그대로 남아 있어,
아이디 admin 과 글자가 겹치는 현상이 나타나고 있습니다.

naver 메인화면의 로그인에서도 같은 현상이 나타나는 것을 확인할 수 있습니다.
그럼 이제 자바스크립트가 꺼진 상태에서도 레이블과 인풋박스의 글자겹침(장애)없이 식별할 수 있도록 해보겠습니다.
우선 스타일 부분에서 일정 부분은 포기를 했습니다. 비슷하게 구현하는 방법이 없진 않겠지만 시간과 노력, 코드의 양이 많으므로 간단하게 아래와 같은 디자인을 적용하겠습니다.

자바스크립트가 꺼졌을 때의 로그인 화면
html 위와 같음css#ol_id {display:block;margin-bottom:3px;padding:0 5px;width:185px;height:22px;border:1px solid #d7d7d7;background:#fff;line-height:1.6em}.ol_idlabel {position:absolute;top:23px;left:20px;color:#696969}#ol_pw {display:block;margin-bottom:3px;padding:0 5px;width:185px;height:22px;border:1px solid #d7d7d7;background:#fff;line-height:1.6em}.ol_pwlabel {position:absolute;top:50px;left:20px;color:#696969}js$(document).ready(function(){$omi = $('#ol_id');$omp = $('#ol_pw');$omp.css('display','inline-block');$omp.css('width',121);$omi_label = $('#ol_idlabel');$omp_label = $('#ol_pwlabel');$omi_label.addClass('ol_idlabel');$omp_label.addClass('ol_pwlabel');$omi.focus(function() {$omi_label.css('visibility','hidden');});$omp.focus(function() {$omp_label.css('visibility','hidden');});$omi.blur(function() {$this = $(this);if($this.attr('id') == "ol_id" && $this.attr('value') == "") $omi_label.css('visibility','visible');});$omp.blur(function() {$this = $(this);if($this.attr('id') == "ol_pw" && $this.attr('value') == "") $omp_label.css('visibility','visible');});});
처음 코드와 달라진 부분은?
초록색은 처음 코드, 빨간색은 처음 코드가 바뀐 부분입니다.
파란색은 추가된 코드입니다.
css#ol_id{display:block;margin-bottom:3px;padding:0 5px;width:185px;height:22px;border:1px solid #d7d7d7;background:#fff;line-height:1.6em}#ol_idlabel {z-index:2;position:absolute;top:23px;left:20px;color:#696969}.ol_idlabel {position:absolute;top:23px;left:20px;color:#696969}#ol_pw {padding:0 5px;width:121px;height:22px;border:1px solid #d7d7d7;background:#fff;line-height:1.6em}#ol_pw {display:block;margin-bottom:3px;padding:0 5px;width:185px;height:22px;border:1px solid #d7d7d7;background:#fff;line-height:1.6em}#ol_pwlabel {z-index:2;position:absolute;top:50px;left:20px;color:#696969}.ol_pwlabel {position:absolute;top:50px;left:20px;color:#696969}js$(document).ready(function(){$omi = $('#ol_id'); //아이디 입력창$omp = $('#ol_pw'); //패스워드 입력창$omp.css('display','inline-block');$omp.css('width',121);$omi_label = $('#ol_idlabel'); //아이디 레이블$omp_label = $('#ol_pwlabel'); //패스워드 레이블$omi_label.addClass('ol_idlabel');$omp_label.addClass('ol_pwlabel');$omi.focus(function() { //아이디 입력창 포커스$omi_label.css('visibility','hidden');});$omp.focus(function() { //패스워드 입력창 포커스$omp_label.css('visibility','hidden');});$omi.blur(function() { //아이디 입력창 포커스 해제$this = $(this);if($this.attr('id') == "ol_mb_id" && $this.attr('value') == "") $omi_label.css('visibility','visible');});$omp.blur(function() { //패스워드 입력창 포커스 해제$this = $(this);if($this.attr('id') == "ol_mb_pw" && $this.attr('value') == "") $omp_label.css('visibility','visible');});});
이 팁의 기본은 자바스크립트를 끈 상태에서부터 퍼블리싱을 시작하여,
자바스크립트를 활용할 수 있다면 원하는 효과를 부분적으로 적용하여 완성한다는 것입니다.
코드를 처음부터 새로 짠게 아니고 있던 것을 접근성에 맞게 개편하다보니 조금 지저분하고, 정리하는 과정에서 약간의 오차가 있을 수 있습니다. ㅠㅠ
댓글 15개
게시글 목록
| 번호 | 제목 |
|---|---|
| 12413 | |
| 12412 | |
| 12411 |
JavaScript
실시간 카운트 다운 시계 입니다.
|
| 12410 |
jQuery
jQuery, 이미지맵 마우스오버시 하이라이트 표시
|
| 12407 | |
| 12406 | |
| 12405 | |
| 12404 |
JavaScript
한번만 submit 되게 하기 입니다.
|
| 12403 |
JavaScript
영문자나 숫자만 입력 할 수 있게 하기 입니다.
|
| 12402 |
JavaScript
현재 페이지 이메일로 보내는 버튼 만들기 입니다.
|
| 12401 |
JavaScript
모바일웹에서 PC버전 링크
|
| 12400 |
JavaScript
특정 파일형태만 업로드 하기 입니다.
|
| 12399 |
JavaScript
입력 문자열 앞에 붙는 공백 제거하기 입니다.
|
| 12398 |
JavaScript
키보드 방향키로 창의 위치를 이동시키기 입니다.
|
| 12397 | |
| 12396 | |
| 12395 |
JavaScript
키보드 눌러 이동하는 단축키 사용하기 입니다.
|
| 12394 |
JavaScript
책장을 넘기는 것같은 이미지 슬라이드 쇼 입니다.
|
| 12393 |
JavaScript
마우스를 대면 링크 이미지들을 보여주기 입니다.
|
| 12392 |
PHP
pushbullet 푸시 발송
|
| 12391 |
MySQL
같은 컬럼의 행들을 한번에 UPDATE 하기
|
| 12390 |
JavaScript
이미지들을 보여주는 풀다운 콤보메뉴 입니다.
|
| 12389 |
JavaScript
부드럽게 오버랩되는 이미지 슬라이드 쇼 입니다.
|
| 12388 |
JavaScript
끊김없이 연속적으로 스크롤 되는 이미지 스크롤러 입니다.
|
| 12387 |
PHP
php 주요 정리 입니다.
|
댓글 작성
댓글을 작성하시려면 로그인이 필요합니다.
로그인하기