테스트 사이트 - 개발 중인 베타 버전입니다

요즘 Focus된 필드는 색깔을 표시하고 Blur될때 다시 원상복귀되는 형태의
폼들이 많이 나오고 잇네요.. 머 네이버도 부분적으로 사용하고 있는거 같고..
소스는 간단합니당. ^^;;
<style type='text/css'>
.din{border:1px solid #FF0000;}
.dout{border:1px solid #000000;}
</style>

<form name='aaa'>
<input type=text name='' onfocus='input_focus(this);' class='dout'>
<input type=text name='' onfocus='input_focus(this);' class='dout'>
</form>

<script language='javascript'>
function input_focus(obj){
 $(obj).addClass('din')
  .removeClass('dout')
  .blur(function(){
  $(this).addClass('dout')
   .removeClass('din');
 });
}
</script>

onfocus 이벤트를 주어서 직접 컨트롤 하는 방법과
아래의 경우처럼 클래스 셀렉터를 이용해 전체적으로 컨트롤 하는 방법이 있습니다.
<input type=text name='' class='dout'>
<input type=text name='' class='dout'>

<script language='javascript'>
$(".dout").focus(function(){
 $(this).addClass('din')
  .removeClass('dout')
  .blur(function(){
   $(this).addClass('dout')
    .removeClass('din');
  });
});
</script>
뭐 장단점이 있겠지만 저는 아래걸 쓰고싶네요.. html코딩도 줄어들고..

좀 이거 아이러니 한게 제가 못 찾아서 그런지는 모르겠지만..
addClass와 removeClass를 같이 써야 한다는게 참 거시기 하네요..
단일지정 함수는 없는걸까요??
javascript의 className 요녀석을 써도 괜찮을거 같은데..


[이 게시물은 관리자님에 의해 2011-10-31 16:55:28 jQuery에서 이동 됨]

댓글 작성

댓글을 작성하시려면 로그인이 필요합니다.

로그인하기

댓글 4개

좋은 팁 감사드립니다.

아랫부분은 속성을 바꿔주는 것으로 될 겁니다.

$(this).addClass('din').removeClass('dout')
->
$(this).attr("class","din");
좋은팁 감사합니다.
단간하게 :focus 속성으로도 가능합니다. ex) input:focus { border:1px solid #888; }
오늘 한참찾았는데.. 드디어 찾았네요.
잘쓰겠습니다~

게시판 목록

프로그램

글쓰기