메뉴 건너뛰기

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

단축키

Prev이전 문서

Next다음 문서

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

단축키

Prev이전 문서

Next다음 문서

크게 작게 위로 아래로 댓글로 가기 인쇄
많이들 보는 형태의 테이블이다. 각 row 에 체크박스가 있고 헤더에 있는 체크박스를 선택하면 모든 체크박스들이 싹다 선택되고 하는 고런 기능이다~

대충 뭐 어떤 기능인지는 알고 있을테니 자세한 기능 설명은 생략한다. (직접 클릭해 보기 바람)

체크박스 전체선택 테스트
제목 날짜
제목1 날짜1
제목2 날짜2
제목3 날짜3
제목4 날짜4
제목5 날짜5
제목6 날짜6





소스는 요렇다. 얼핏보면 은근 복잡해 보이기도 한데

그냥 별 생각없이 예제를 만들다 보니 그런것도 있고~ jQuery 의 함수들을 이것저것 복합 다양하게 일부러 쓴 경향도 있다.



이왕이면 여러가지 것들을 써 봄으로써 몰랐던 jQuery 의 쓰임새도 추가적으로 파악할 수 있지 않을까 하는 고런 마음에서 -_-;;

jQuery 함수 이름들이 워낙 이해하기 쉽게 명료하게 되 있어서, 소스를 그냥 눈에 읽히는데로 쭉 읽으면 대충은 이해되지 않을까 한다~



별건 아니면서 허접한 소스지만, 소스를 보고 요 소스가 우째 죠런 기능을 하게 맹글까? 라는 이해를 하게 된다면

jQuery 사용법에 대해서 전 보다는 많이 알고 있는 상태로 변할 것이라고 믿어 의심치 않는다~

<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
<html>
<head>
    <script src="http://ajax.googleapis.com/ajax/libs/jquery/1.6.4/jquery.min.js" type="text/javascript"></script>
 
    <script>
        $(document).ready(function(){
            var tbl = $("#checkboxTestTbl");
             
            // 테이블 헤더에 있는 checkbox 클릭시
            $(":checkbox:first", tbl).click(function(){
                // 클릭한 체크박스가 체크상태인지 체크해제상태인지 판단
                if( $(this).is(":checked") ){
                    $(":checkbox", tbl).attr("checked", "checked");
                }
                else{
                    $(":checkbox", tbl).removeAttr("checked");
                }
 
                // 모든 체크박스에 change 이벤트 발생시키기                
                $(":checkbox", tbl).trigger("change");
            });
             
            // 헤더에 있는 체크박스외 다른 체크박스 클릭시
            $(":checkbox:not(:first)", tbl).click(function(){
                var allCnt = $(":checkbox:not(:first)", tbl).length;
                var checkedCnt = $(":checkbox:not(:first)", tbl).filter(":checked").length;
                 
                // 전체 체크박스 갯수와 현재 체크된 체크박스 갯수를 비교해서 헤더에 있는 체크박스 체크할지 말지 판단
                if( allCnt==checkedCnt ){
                    $(":checkbox:first", tbl).attr("checked", "checked");
                }
                else{
                    $(":checkbox:first", tbl).removeAttr("checked");
                }
            }).change(function(){
                if( $(this).is(":checked") ){
                    // 체크박스의 부모 > 부모 니까 tr 이 되고 tr 에 selected 라는 class 를 추가한다.
                    $(this).parent().parent().addClass("selected");
                }
                else{
                    $(this).parent().parent().removeClass("selected");
                }
            });
        });
    </script>
     
    <style>
        #checkboxTestTbl {border-collapse: collapse;}
        #checkboxTestTbl td, #checkboxTestTbl th{padding:20px;}
        #checkboxTestTbl th{background-color: #ccc;}
         
        #checkboxTestTbl tr.selected{background-color: navy;color: #fff; font-weight: bold;}
    </style>
</head>
 
<body>
    <table id="checkboxTestTbl" border="1px">
        <caption>체크박스 전체선택 테스트</caption>
        <colgroup>
            <col width="40px;"/>
            <col width="200px;"/>
            <col width="100px;"/>
        </colgroup>
        <tr>
            <th><input type="checkbox"/></th>
            <th>제목</th>
            <th>날짜</th>
        </tr>
        <tr>
            <td><input type="checkbox" /></td>
            <td>제목1</td>
            <td>날짜1</td>
        </tr>
        <tr>
            <td><input type="checkbox" /></td>
            <td>제목2</td>
            <td>날짜2</td>
        </tr>
        <tr>
            <td><input type="checkbox" /></td>
            <td>제목3</td>
            <td>날짜3</td>
        </tr>
        <tr>
            <td><input type="checkbox" /></td>
            <td>제목4</td>
            <td>날짜4</td>
        </tr>
        <tr>
            <td><input type="checkbox" /></td>
            <td>제목5</td>
            <td>날짜5</td>
        </tr>
        <tr>
            <td><input type="checkbox" /></td>
            <td>제목6</td>
            <td>날짜6</td>
        </tr>
    </table>
</body>
</html>


  1. jquery timer, javascript countdown (타이머 예제)

    Date2018.11.07 Views81532
    Read More
  2. jquery 플러그인 링크 모음

    Date2016.12.22 Views49637
    Read More
  3. 동적으로 콤보(select)의 항목(option) 생성하기

    Date2016.09.21 Views14377
    Read More
  4. 이미지 클릭시 확대하기

    Date2016.09.21 Views12650
    Read More
  5. jqGrid / custom pager / custom paging / 그리드 / 페이징

    Date2016.09.09 Views12534
    Read More
  6. Ajax를 통해 전송된 데이터를 Controller에서 List 객체로 받기

    Date2021.03.25 Views12247
    Read More
  7. jQuery 입문: form 데이터 유효성 검사

    Date2017.03.02 Views11799
    Read More
  8. 속성선택자를 이용해서 링크에 스타일 입히기

    Date2016.09.21 Views11574
    Read More
  9. Ajax를 이용한 데이터 조회시 로딩 로딩 이미지 보이기(jquery이용)

    Date2016.12.22 Views10746
    Read More
  10. jquery 이용한 필수입력체크(input form)

    Date2017.03.02 Views10559
    Read More
  11. 셀렉트박스에서 특정 옵션 선택시 레이어 나타내기

    Date2016.12.22 Views10486
    Read More
  12. bxslider 멈춤현상

    Date2016.12.22 Views10116
    Read More
  13. jQuery 날짜 비교 (날짜비교)

    Date2016.11.17 Views10066
    Read More
  14. jquery radio checked (라디오 버튼 값으로 선택), 검색 조건 초기 셋팅

    Date2016.11.17 Views10046
    Read More
  15. 각종 다이어그램 플러그인 / 차트 / 관계 플러그인

    Date2016.09.09 Views9489
    Read More
  16. POST 방식으로 인수를 전달하고 그 결과를 받아오기

    Date2016.09.21 Views9202
    Read More
  17. select box 값 변경, 목록 변경

    Date2016.09.21 Views9065
    Read More
  18. 파일 업로드 방법, 이미지 파일 업로드 예제 소스

    Date2017.03.06 Views9028
    Read More
  19. [jQuery] 이용 아이디 중복체크 실시간

    Date2016.09.11 Views8876
    Read More
  20. jquery 글자 byte, 문자열 byte(바이트) 길이 체크하기 예제

    Date2016.11.17 Views8839
    Read More
Board Pagination Prev 1 2 3 4 5 6 7 8 9 Next
/ 9

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

© k2s0o1d4e0s2i1g5n. All Rights Reserved