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

텍스트 필드 css 적용하기..

· 16년 전 · 2195 · 4

요즘 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");
좋은팁 감사합니다.
16년 전
단간하게 :focus 속성으로도 가능합니다. ex) input:focus { border:1px solid #888; }
14년 전
오늘 한참찾았는데.. 드디어 찾았네요.
잘쓰겠습니다~

게시글 목록

번호 제목
28213
31006
7898
7897
19935
7892
7885
31005
28209
7880
7877
7871
7865
7862
7858
7852
19933
19931
19928
19927
31003
19920
28206
19918
28200
7850
19916
28180
28165
19911
7842
7838
7830
7818
28150
19906
19905
19903
19901
19900
28145
7815
31002
7803
7799
7785
19898
7780
7779
7777
7776
7775
7758
19893
19892
19891
20850
19885
7752
7747
7738
19883
7735
28139
7734
7731
7725
7717
19879
7715
7710
19858
7709
7703
28134
28129
7694
7690
28125
7672
7660
28111
19857
19856
7658
28106
28098
7655
28095
7651
19851
7646
19850
24661
28089
7633
7623
28087
28085
7620