씨네
공부하는 개발자 강씨네
씨네
  • 분류 전체보기 (460)
    • Web (21)
      • HTML (11)
      • CSS (10)
    • JS 관련 (49)
      • JavaScript (27)
      • JQuery (22)
    • TS 관련 (15)
      • TypeScript (15)
    • NodeJS (7)
      • NodeJS (7)
    • 따라하며 배우는 시리즈 (23)
      • NodeJS & ReactJS Basic (23)
      • NodeJS & ReactJS Movie (0)
      • NodeJS & ReactJS Youtube (0)
      • NodeJS & ReactJS ChatBot (0)
    • SPA (14)
      • React (14)
      • Vue (0)
      • Anguler (0)
    • Java 관련 (118)
      • Java (52)
      • JDBC (6)
      • JSP & Servlet (18)
      • Spring Legecy (38)
      • SpringBoot (4)
    • Python (26)
      • Python (20)
      • PyMongo (1)
      • Django (5)
    • Git (24)
      • Github (24)
    • RDB (22)
      • Oracle (21)
      • MySQL (1)
    • NoSQL (5)
      • MongoDB (5)
    • OS (4)
      • Linux (4)
    • 빅데이터 (2)
      • hadoop (2)
    • IDE (20)
      • eclipse (11)
      • VSCODE (4)
      • VisualStudio (1)
      • IntelliJ (1)
      • PyCharm (1)
      • DBeaver (2)
    • Install (3)
      • Tomcat (1)
      • Docker (1)
      • Anaconda (1)
    • 오류&에러 (28)
      • TS (2)
      • NodeJS (7)
      • SQL (8)
      • Java (1)
      • Spring (4)
      • Git (6)
      • 기타 (0)
    • 알고리즘 (67)
      • 수열 (1)
      • 백준(backjoon) (39)
      • Programmers (27)
    • 자격증 (5)
      • SQLD (5)
    • 기타 (2)
    • IT유튜브로 지식쌓기 (2)

공지사항

인기 글

최근 글

티스토리

250x250
hELLO · Designed By 정상우.
씨네

공부하는 개발자 강씨네

[jQuery] checkbox( 전체선택 )
JS 관련/JQuery

[jQuery] checkbox( 전체선택 )

2022. 2. 12. 14:50
728x90
<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<title>Insert title here</title>
<script type="text/javascript" src="resources/js/jquery-3.5.1.min.js"></script>
<script type="text/javascript">
	
$(function(){
	$("#confirm").click(function(){
		$("#result").empty();
		
		//유효값처리
		if($("input[name=chk]:checked").length == 0){
			alert("하나 이상 선택해 주세요");
		}else{
			var total = 0;
			$("input[name=chk]:checked").each(function(i){
				//var chk = $(this);
				var chk = $("input[name=chk]:checked").eq(i);
				var book = chk.next().text();
				var price = chk.val();
				
				$("#result").append(book + " : " + price + "<br>");
				total += parseInt(price);
			});
			$("#result").append("총 : " + total);
		}
	});
	
	
	$("input[name=chk]").click(function(){
		if ($("input[name=chk]").length == $("input[name=chk]:checked").length) {
			$("input[name=all]").prop("checked",true);
		}else{
			$("input[name=all]").prop("checked",false);
		}
	});
});	


	function allcheck(bool){
		$("input[name=chk]").each(function(){
			// .attr : html의 속성(attrubute)
			// .prop : javascript의 속성(property)
			$(this).prop("checked", bool);
		})
	}

</script>
</head>
<body>
	
	<fieldset style="width: 300px;">
		<legend>체크 여부 확인</legend>
		
		<input type="checkbox" name="all" onclick="allcheck(this.checked);">전체 선택<br>
		
		<input type="checkbox" name="chk" value="30000"><b>Java</b><br>
		<input type="checkbox" name="chk" value="25000"><b>Oracle</b><br>
		<input type="checkbox" name="chk" value="20000"><b>JavaScript</b><br>
		
		<input type="button" value="확인" id="confirm"><br>
		<span>선택한 책 가격</span>
		<div id="result"></div>
	</fieldset>

</body>
</html>

​

​

체크박스가 하나도 선택되지 않았을경우 하나 이상 선택해 주세요라는 메세지를 출력시킵니다.

$(function(){
	$("#confirm").click(function(){
		$("#result").empty();
		
		//유효값처리
		if($("input[name=chk]:checked").length == 0){
			alert("하나 이상 선택해 주세요");
		}else{
			var total = 0;
			$("input[name=chk]:checked").each(function(i){
				//var chk = $(this);
				var chk = $("input[name=chk]:checked").eq(i);
				var book = chk.next().text();
				var price = chk.val();
				
				$("#result").append(book + " : " + price + "<br>");
				total += parseInt(price);
			});
			$("#result").append("총 : " + total);
		}
	});
});

만약 하나 이상 선택되어있다면 각 책의 이름과 가격이 나오고 가격의 총합을 계산해줍니다.

가격은 checkbox의 value입니다.

​

​

$(function(){
	$("input[name=chk]").click(function(){
		if ($("input[name=chk]").length == $("input[name=chk]:checked").length) {
			$("input[name=all]").prop("checked",true);
		}else{
			$("input[name=all]").prop("checked",false);
		}
	});
});

이 함수는 전체선택버튼이 true가 되면 나머지 checkbox 모두 true가 되고 전체선택 checkbox가 false가 되면 나머지 checkbox 모드 false가 되는 함수입니다.

 

​

​

​

function allcheck(bool){
	$("input[name=chk]").each(function(){
		// .attr : html의 속성(attrubute)
		// .prop : javascript의 속성(property)
		$(this).prop("checked", bool);
	})
}

전체선택을 누르지 않아도 모든checkbox가 true이면 전체선택 checkbox도 true가 됩니다.

또한 모두 true값이었다가 하나만 false가 되어도 전체 선택 checkbox도 false가 됩니다.

 
728x90

'JS 관련 > JQuery' 카테고리의 다른 글

[jQuery] add(), is()  (0) 2022.02.15
[jQuery] find(), children(), parent(), next()  (0) 2022.02.14
[jQuery] submit 활용해보기  (0) 2022.02.11
[jQeury] val()(value값 가져오기)  (0) 2022.02.10
[jQeury] 제이쿼리 연습! (선택자 / hide, slideup 등)  (0) 2022.02.09
    'JS 관련/JQuery' 카테고리의 다른 글
    • [jQuery] add(), is()
    • [jQuery] find(), children(), parent(), next()
    • [jQuery] submit 활용해보기
    • [jQeury] val()(value값 가져오기)
    씨네
    씨네
    개발자 씨네가 공부하는 내용을 기록 겸 공유하는 블로그입니다!

    티스토리툴바