씨네
공부하는 개발자 강씨네
씨네
  • 분류 전체보기 (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 정상우.
씨네

공부하는 개발자 강씨네

[JavaScript] checkbox로 개별선택, 전체선택 함수 만들기
JS 관련/JavaScript

[JavaScript] checkbox로 개별선택, 전체선택 함수 만들기

2022. 1. 25. 12:35
728x90

<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<title>Insert title here</title>

<style type="text/css">
	#colorbox{
		width: 320px;
		height: 320px;
		position: relative;
	}
	#red, #green, #blue, #purple{
		width: 150px;
		height: 150px;
		border: 1px solid black;
		position: absolute;
	}
	#green{left: 160px;}
	#blue{top: 160px;}
	#purple{top: 160px; left: 160px;}
</style>
<script type="text/javascript">

	// bool = this.checked : name이 all인 체크박스의 체크속성( ture, false )
	function allselect(bool){
		var chks = document.getElementsByName("chk");
		for(var i = 0; i < chks.length; i++){
			chks[i].checked = bool;
		}
	}
	
	function sel(){
		// 1. chk라는 이름을 가진 모든 checkbox 가져온다.
		var chks = document.getElementsByName("chk");
		
		for(var i = 0; i < chks.length; i++){
			// 2. 만일 chk들 중에 체크되어있는 element가 있다면,
			if( chks[i].checked ){
				// 3. 체크되어있는 chk.value값을 Id로 가지는 요소의 배경색을 chk.value값으로 바꾸자.
				// document.getElementById(???).stlye.backgroundColor=???
				document.getElementById(chks[i].value).style.background = chks[i].value;
			} else {
				document.getElementById(chks[i].value).style.background = "";
			}
		}
	}
	
	function clearDiv(){
		var chks = document.getElementsByName("chk");
		
		for(var i = 0; i < chks.length; i++){
				document.getElementById(chks[i].value).style.background = "";
		}
		document.getElementsByName("all")[0].checked = false;
		allselect(false);
	}

</script>

</head>
<body>

	<div id="colorbox">
		<div id="red">red</div>
		<div id="green">green</div>
		<div id="blue">blue</div>
		<div id="purple">purple</div>
	</div>
	
	<div>
		<form>
			<input type="checkbox" name="all" onclick="allselect(this.checked);">전체선택<br>
			
			<input type="checkbox" name="chk" value="red" onclick="checked();">빨강<br>
			<input type="checkbox" name="chk" value="green" onclick="checked();">초록<br>
			<input type="checkbox" name="chk" value="blue" onclick="checked();">파랑<br>
			<input type="checkbox" name="chk" value="purple" onclick="checked();">보라<br>
			
			<input type="button" value="선택" onclick="sel();">
			<input type="button" value="초기화" onclick="clearDiv();">
			<div id="aaa"></div>
		</form>
	</div>

</body>
</html>

​

​

​

function sel(){
	// 1. chk라는 이름을 가진 모든 checkbox 가져온다.
	var chks = document.getElementsByName("chk");
		
	for(var i = 0; i < chks.length; i++){
		// 2. 만일 chk들 중에 체크되어있는 element가 있다면,
		if( chks[i].checked ){
			// 3. 체크되어있는 chk.value값을 Id로 가지는 요소의 배경색을 chk.value값으로 바꾸자.
			// document.getElementById(???).stlye.backgroundColor=???
			document.getElementById(chks[i].value).style.background = chks[i].value;
		} else {
			document.getElementById(chks[i].value).style.background = "";
		}
	}
}

해당 함수로 인해 체크박스에 체크를 하고 선택 버튼을 누르면 해당 영역의 배경색이 바뀝니다.

​

​

​

function clearDiv(){
	var chks = document.getElementsByName("chk");
		
	for(var i = 0; i < chks.length; i++){
			document.getElementById(chks[i].value).style.background = "";
	}
	document.getElementsByName("all")[0].checked = false;
	allselect(false);
}

초기화 버튼을 누르면 처음 상태로 돌아옵니다.

​

​

​

function allselect(bool){
	var chks = document.getElementsByName("chk");
	for(var i = 0; i < chks.length; i++){
		chks[i].checked = bool;
	}
}

해당함수는 전체선택 버튼 왼쪽의 체크박스에 적용되어있습니다.

전체선택을 누르면 모든 checkbox가 true가 됩니다

728x90

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

[JavaScript] DOM(parentNode / childNodes)  (0) 2022.01.27
[JavaScript] select(리스트 선택)  (0) 2022.01.26
[JavaScript] location(reload / href / assign / replace)  (0) 2022.01.24
[JavaScript] Window객체, 간단한 회원가입 페이지 만들기  (0) 2022.01.23
[JavaScript] 팝업창!(pop up)  (0) 2022.01.22
    'JS 관련/JavaScript' 카테고리의 다른 글
    • [JavaScript] DOM(parentNode / childNodes)
    • [JavaScript] select(리스트 선택)
    • [JavaScript] location(reload / href / assign / replace)
    • [JavaScript] Window객체, 간단한 회원가입 페이지 만들기
    씨네
    씨네
    개발자 씨네가 공부하는 내용을 기록 겸 공유하는 블로그입니다!

    티스토리툴바