씨네
공부하는 개발자 강씨네
씨네
  • 분류 전체보기 (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] DOM(parentNode / childNodes)
JS 관련/JavaScript

[JavaScript] DOM(parentNode / childNodes)

2022. 1. 27. 09:41
728x90

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

	function searchPar(){
		var child02 = document.getElementsByTagName("p")[1];
		var parent = child02.parentNode;
		console.log(parent);
		alert(parent.nodeName);
		parent.style.backgroundColor='pink';
	}

	function searchChi(){
		var div = document.getElementsByTagName("div")[0];
		//alert(div.length);
		
		// childNodes : 자식 노드들을 배열로 반환
		var divChildren = div.childNodes;
		console.log(divChildren);
		divChildren[5].style.color="blue";
		divChildren[5].style.backgroundColor="black";
	}
	
	function test01(){
		var ch = document.getElementsByTagName("p")[3];
		var pa = ch.parentNode;
		pa.style.backgroundColor="#F3E2A9";
	}
	
	function test02(){
		var div = document.getElementsByTagName("div")[2];
		var children = div.childNodes[3];
		children.style.fontSize="20pt";
	}

</script>
</head>
<body>

	<h1>부모탐색, 자식탐색</h1>

	<div>
		<p>child01</p>
		<p>child02</p>
		<p>child03</p>
	</div>
	
	<button onclick="searchPar();">부모탐색</button>
	<button onclick="searchChi();">자식탐색</button>
	
	<!-- 문제 -->
	<h3 onclick="test01();">1. "test01을 포함하는 부모태그"의 배경색을 지정하자</h3>
	<!-- parentNode 사용하기! -->
	
	<h3 onclick="test02();">2. "세번째 div 태그에 포함된 test04"의 폰트 크기를 20pt로 적용하자</h3>
	
	<div>
		<p>test01</p>
		<p>test02</p>
	</div>
	<div>
		<p>test03</p>
		<p>test04</p>
	</div>
</body>
</html>

​

​

​

function searchPar(){
	var child02 = document.getElementsByTagName("p")[1];
	var parent = child02.parentNode;
	console.log(parent);
	alert(parent.nodeName);
	parent.style.backgroundColor='pink';
}
 

부모탐색 버튼을 누르면 해당 함수가 실행됩니다.

<div>
	<p>child01</p>
	<p>child02</p>
	<p>child03</p>
</div>

그러면 HTML영역에 있는 해당 코드에서 이벤트가 발생합니다.

1번지의 <P>태그인 child02 부분의 부모태그인 <DIV>영역이 이벤트를 발생 시키겠네요!

이벤트는 배경색을 pink색으로 바꾸는것 이었습니다.

​

​

​

function searchChi(){
	var div = document.getElementsByTagName("div")[0];
	alert(div.length);
		
	// childNodes : 자식 노드들을 배열로 반환
	var divChildren = div.childNodes;
	console.log(divChildren);
	divChildren[5].style.color="blue";
	divChildren[5].style.backgroundColor="black";
}
 

자식탐색 버튼을 누르면 해당 함수가 실행됩니다.

0번지에 담긴 <div>태그를 찾아 배열의 길이를 출력합니다.

출력 결과는 undefined입니다.

childNodes는 자식 노드들을 배열로 담게됩니다.

함수에서는 해당 <div>의 자식요소들을 배열로 저장합니다.

콘솔창에 출력된 결과를 보면 해당 배열의 길이는 7이며 태그뿐만아니라 text도 배열에 포함되는걸 알수 있습니다.

​

​

​

​

​

	<div>
		<p>test01</p>
		<p>test02</p>
	</div>
	<div>
		<p>test03</p>
		<p>test04</p>
	</div>

아래쪽 함수들은 HTML영역중 해당영역에서 이벤트가 발생합니다.

<div>는 각각 1번지, 2번지에 저장되어있습니다.

<p>태그는 3번지부터 시작하겠네요.

function test01(){
	var ch = document.getElementsByTagName("p")[3];
	var pa = ch.parentNode;
	pa.style.backgroundColor="#F3E2A9";
}

3번지에 있는 p태그의 부모의 배경색을 변경합니다.

​

​

​

function test02(){
	var div = document.getElementsByTagName("div")[2];
	var children = div.childNodes[3];
	children.style.fontSize="20pt";
}

해당 함수는 2번지에 있는 <div>태그의 자식요소중 3번지에 저장되어있는 배열의 폰트크기를 변경합니다.

0번지에는 text03글자가 담겨있는 <p>태그 1번지에는 text가 2번지에는 text04라는 글자를 감싸고 있는 <p>태그입니다!

728x90

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

[JavaScript] DOM( img바꾸기 )  (0) 2022.01.29
[JavaScript] DOM( createElement / createAttribute )  (0) 2022.01.28
[JavaScript] select(리스트 선택)  (0) 2022.01.26
[JavaScript] checkbox로 개별선택, 전체선택 함수 만들기  (0) 2022.01.25
[JavaScript] location(reload / href / assign / replace)  (0) 2022.01.24
    'JS 관련/JavaScript' 카테고리의 다른 글
    • [JavaScript] DOM( img바꾸기 )
    • [JavaScript] DOM( createElement / createAttribute )
    • [JavaScript] select(리스트 선택)
    • [JavaScript] checkbox로 개별선택, 전체선택 함수 만들기
    씨네
    씨네
    개발자 씨네가 공부하는 내용을 기록 겸 공유하는 블로그입니다!

    티스토리툴바