메뉴 건너뛰기

조회 수 568 추천 수 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 11Sep
    by
    2016/09/11 Views 7179 

    [jQuery Plugin] FCKeditor 2.6.5 사용법

  2. No Image 06Oct
    by
    2016/10/06 Views 7181 

    zeroclipboard - 클립보드 복사하기(자바스크립트 클립보드 복사하기)

  3. Table을 DIV로 표현하기 (예제)

  4. No Image 26Mar
    by
    2021/03/26 Views 1368 

    selectbox multiple 선택한 값들 submit 해서 받기

  5. No Image 26Mar
    by 조쉬
    2021/03/26 Views 568 

    SELECTBOX MULTIPLE 검색하기

  6. No Image 21Sep
    by
    2016/09/21 Views 9065 

    select box 값 변경, 목록 변경

  7. No Image 22Dec
    by
    2016/12/22 Views 6470 

    scrolling to top

  8. No Image 25Mar
    by
    2021/03/25 Views 170 

    radio 제어하기

  9. Query 기초 (동적 테이블 (데이터 추가 / 삭제), integrateTable(정렬(sort))

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

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

  11. No Image 21Sep
    by
    2016/09/21 Views 9202 

    POST 방식으로 인수를 전달하고 그 결과를 받아오기

  12. popModal jQuery Plugin Examples / 무료 jQuery 팝업 플러그인

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

    parent of the iframe element selector

  14. Magnific popup conflict with "jquery.nicescroll"

  15. No Image 21Sep
    by
    2016/09/21 Views 6412 

    load() 메소드

  16. No Image 04Jun
    by
    2019/06/04 Views 745 

    JS 타이머 샘플

  17. No Image 04Jun
    by
    2019/06/04 Views 694 

    JS 첵박스 샘플

  18. No Image 04Jun
    by
    2019/06/04 Views 788 

    JS 날짜 자료 비교

  19. No Image 27Mar
    by
    2017/03/27 Views 8704 

    jquery를 활용한 입력폼 초기화하기

  20. jQuery를 이용한 스크롤 따라니는 배너를 쉽게 맨들기(scroll follow)

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

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

© k2s0o1d4e0s2i1g5n. All Rights Reserved