메뉴 건너뛰기

조회 수 603 추천 수 0 댓글 0
?

단축키

Prev이전 문서

Next다음 문서

크게 작게 위로 아래로 댓글로 가기 인쇄
?

단축키

Prev이전 문서

Next다음 문서

크게 작게 위로 아래로 댓글로 가기 인쇄

select box 에 여러 항목이 있을때 해당 검색을 해주는 걸 만들어 보았다. 예제 소스를 나름데로 잘 만들어 놓은거 같으니, 알아서 잘 참조해보기 바란다.

<input type="text" name="k1" id="k1">
<input type="button" name="b1" id="b1" value="다중검색">
<input type="button" name="b2" id="b2" value="단일검색"><br>
<select multiple name="s1" id="s1" style="height:150px;width:150px;"></select>

<script type="text/javascript" src="http://code.jquery.com/jquery-latest.min.js"></script>
<script>
$(function(){
 for( var i = 10000; i<=12345; i++) $('#s1').append("<option value='"+i+"'>"+i+"</optoin>"); //selectbox에 임의의 순차적인 숫자 부여
 
 $('#b1').click( function(){ //다중검색

  if( !$('#k1').val() )
  {
   alert( "검색어를 입력해주세요.");
   $('#k1').focus();
   return false;
  }
  else
  {
   var s_item = $('#k1').val();
  }

  var scroll_height = $('#s1').prop('scrollHeight'); // 셀렉트박스의 스크롤 길이
  var this_count = $('#s1 option').size(); // 셀렉트박스의 count
  var this_height = scroll_height/this_count;
  var i = 0;

  $('#s1 option').each( function(){
   if( $(this).val().toLowerCase().indexOf( s_item.toLowerCase() ) >= 0 && $(this).attr('selected') != 'selected' )
   {
    var tst = Math.round(this_height*i); //이동될 스크롤 계산
    $(this).attr("selected", "selected");
    $('#s1').scrollTop( tst );
    return false;
   }
   i++;
  });
 });

 $('#b2').click( function(){ // 단일검색

  if( !$('#k1').val() )
  {
   alert( "검색어를 입력해주세요.");
   $('#k1').focus();
   return false;
  }
  else
  {
   var s_item = $('#k1').val();
  }

  var scroll_height = $('#s1').prop('scrollHeight'); // 셀렉트박스의 스크롤 길이
  var this_count = $('#s1 option').size(); // 셀렉트박스의 count
  var this_height = scroll_height/this_count;
  var i = 0;

  $('#s1 option').each( function(){ $('#s1').removeAttr('selected'); }); // 셀렉트 된것 해제

  $('#s1 option').each( function(){
   if( $(this).val().toLowerCase().indexOf( s_item.toLowerCase() ) >= 0 )
   {
    var tst = Math.round(this_height*i);
    $(this).attr("selected", "selected");
    $('#s1').scrollTop( tst );
    return false;
   }
   i++;
  });
 });

});
</script>
 
  

간단히 구조를 설명해 주자면...
다중검색일 경우에는 검색 내용이 value로 들어간 option을 찾아서 selected를 먹여주고, 다음 버튼을 누를때는 selected된 것들은 제외 시키고 다음걸 찾는다.
단일검색일 경우에는 검색내용이 value로 들어간 최상단의 1개의 내용만 찾는다.

뭐 이정도 해놨으니, 응용같은건 알아서 해보기 바란다. ㅡ/.ㅡ

//------------- 추가 2014.11.26

<script>
var after_i = -1;
var search_val = '';

$(function(){
 for( var i = 10000; i<=10022; i++) $('#s1').append("<option value='"+i+"'>"+i+"</optoin>"); 
 
 $('#b1').click( function(){

  if( !$('#k1').val() )
  {
   alert( "검색어를 입력해주세요.");
   $('#k1').focus();
   return false;
  }
  else
  {
   var s_item = $('#k1').val();
  }

  if( s_item != search_val )
  {
   after_i = -1;
   search_val = s_item;
  }

  var scroll_height = $('#s1').prop('scrollHeight'); // 셀렉트박스의 스크롤 길이
  var this_count = $('#s1 option').size(); // 셀렉트박스의 count
  var this_height = scroll_height/this_count;
  var i = 0;

  $('#s1 option').each( function(){ $(this).removeAttr('selected'); }); // 셀렉트 된것 해제

  $('#s1 option').each( function(){
   if( $(this).val().toLowerCase().indexOf( s_item.toLowerCase() ) >= 0 && i>after_i)
   {
    var tst = Math.round(this_height*i);
    after_i = i;
    $(this).attr("selected", "selected");
    $('#s1').scrollTop( tst );
    return false;
   }
   if( after_i == i ) after_i = -1;
   i++;
  });
 });

});
</script>
 
 

위의 다중 검색을 조금 수정한 버전이다. 해당 소스는 다중 검색한 것들을 검색버튼을 누를시에 차례대로 다음 걸로 찾아가 주는 소스이다.


  1. No Image 31Mar
    by
    2021/03/31 Views 256 

    행에 징검다리 스타일 입히기 (:odd, :even)

  2. No Image 31Mar
    by
    2021/03/31 Views 288 

    제이쿼리에서 클래스(class) 이름 추가/삭제

  3. No Image 31Mar
    by
    2021/03/31 Views 864 

    click event scroll

  4. No Image 31Mar
    by
    2021/03/31 Views 341 

    click에 따른 마우스 휠 on off

  5. No Image 31Mar
    by
    2021/03/31 Views 352 

    다중 select

  6. No Image 31Mar
    by
    2021/03/31 Views 316 

    draggable - div 드래그

  7. No Image 31Mar
    by
    2021/03/31 Views 394 

    parent of the iframe element selector

  8. No Image 31Mar
    by
    2021/03/31 Views 274 

    prepend / append - element 추가 (부모/자식 관계)

  9. No Image 31Mar
    by
    2021/03/31 Views 216 

    before / after / insertBefore / insertAfter - element 추가 (동등 관계)

  10. No Image 31Mar
    by
    2021/03/31 Views 302 

    마우스 좌표 얻기

  11. No Image 26Mar
    by
    2021/03/26 Views 637 

    간단한 마우스 포인터 따라 다니기

  12. No Image 26Mar
    by
    2021/03/26 Views 300 

    change 전의 값을 가져오기

  13. No Image 26Mar
    by
    2021/03/26 Views 218 

    focus() 로 오브젝트 옮기기

  14. No Image 26Mar
    by
    2021/03/26 Views 878 

    새창(자식창) 제어하기, 새창 POST방식으로 값 넘기기

  15. No Image 26Mar
    by 조쉬
    2021/03/26 Views 603 

    SELECTBOX MULTIPLE 검색하기

  16. easing - 효과의 진행 속도

  17. No Image 26Mar
    by
    2021/03/26 Views 323 

    fadeIn() , fadeOut() 을 이용한 간단한 자동 그림 전환

  18. No Image 26Mar
    by
    2021/03/26 Views 881 

    정규식, 한글 못쓰게 하기, replace all

  19. No Image 26Mar
    by
    2021/03/26 Views 216 

    input checkbox 모두 체크하기

  20. No Image 26Mar
    by
    2021/03/26 Views 1180 

    attr() - style의 특정 속성만 바꾸기

Board Pagination Prev 1 2 3 4 5 6 7 8 9 Next
/ 9

하단 정보를 입력할 수 있습니다

© k2s0o1d4e0s2i1g5n. All Rights Reserved