씨네
공부하는 개발자 강씨네
씨네
  • 분류 전체보기 (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( 태그 추가하기 / 이동하기 )
JS 관련/JavaScript

[JavaScript] DOM( 태그 추가하기 / 이동하기 )

2022. 1. 31. 10:50
728x90

<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<title>Insert title here</title>
<style type="text/css">
	p{
		border: 1px solid red;
	}
</style>
<script type="text/javascript">

	var count = 1;

	function addAppend(){
		var fieldset = document.getElementById("addele");
		
		var p = document.createElement("p");
		p.textContent = "자식요소들 중 가장 마지막에 들어갑니다." + (count++);
		
		fieldset.appendChild(p);
	}
	
	var cnt = 1;
	
	function addBefore(){
		var p = document.createElement("p");
		p.textContent = "선택된 엘리먼트의 앞에 붙여넣어요." + (cnt++);
		
		var div = document.querySelector("fieldset > div");
		var fieldset = document.getElementById("addele");
		fieldset.insertBefore(p, div);
		
	}
	
	function moveElement(){
		var ele = document.querySelector("fieldset").children[1];
		var body = document.body;
		body.appendChild(ele);
	}
</script>
</head>
<body>

	<h1>태그 추가하기</h1>
	
	<button onclick="addAppend();">appendChild</button>
	<button onclick="addBefore();">insertBefore</button>
	<button onclick="moveElement();">appendChild를 이용한 엘리먼트 이동</button>
	
	<fieldset id="addele">
		<legend>부모태그</legend>
		<div>div태그</div>
	</fieldset>
</html>

​

​

​

function addAppend(){
	var fieldset = document.getElementById("addele");
		
	var p = document.createElement("p");
	p.textContent = "자식요소들 중 가장 마지막에 들어갑니다." + (count++);
		
	fieldset.appendChild(p);
}

 

appendChild버튼을 누르면 해당 함수가 실행됩니다.

해당 함수는 id가 addele인 태그 해당코드에서는 fieldset이 되겠네요.

fieldset영영의 가장 마지막에

p.textContent = "자식요소들 중 가장 마지막에 들어갑니다." + (count++);

처럼 <p>태그 영역 안에 텍스트를 생성합니다.

누를때마다 해당 이벤트가 발생합니다.

​

​

​

​

function addBefore(){
		
	var p = document.createElement("p");
	p.textContent = "선택된 엘리먼트의 앞에 붙여넣어요." + (cnt++);
		
	var div = document.querySelector("fieldset > div");
	var fieldset = document.getElementById("addele");
		
	fieldset.insertBefore(p, div);
}

해당 코드는 <p>태그를 생성는 변수를 선언하였습니다.

그리고 <p>태그 안에는 "선택된 엘리먼트의 앞에 붙여넣어요."라는 텍스트를 넣고 cnt++를 통해 입력된 수만큼 숫자가 붙습니다.

마찬가지로 버튼을 클릭한 횟수만큼 생성됩니다.

​

​

​

function moveElement(){
	var ele = document.querySelector("fieldset").children[1];
	var body = document.body;
	body.appendChild(ele);
}

fieldset의 1번지 (0번지는 부모태그라는 텍스트를 감싸고있는 <legend>태그 입니다!)부터 차례대로 body의 맨마지막으로 이동시킵니다!

함수로 생성되지 않은 처음부터 있던 태그도 모두 이동합니다.

728x90

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

[JavaScript] DOM( 태그 생성 및 삭제 )  (0) 2022.02.02
[JavaScript] Dom(태그 이동시키기)  (0) 2022.02.01
[JavaScript] DOM( 이미지 속성 변경 )  (0) 2022.01.30
[JavaScript] DOM( img바꾸기 )  (0) 2022.01.29
[JavaScript] DOM( createElement / createAttribute )  (0) 2022.01.28
    'JS 관련/JavaScript' 카테고리의 다른 글
    • [JavaScript] DOM( 태그 생성 및 삭제 )
    • [JavaScript] Dom(태그 이동시키기)
    • [JavaScript] DOM( 이미지 속성 변경 )
    • [JavaScript] DOM( img바꾸기 )
    씨네
    씨네
    개발자 씨네가 공부하는 내용을 기록 겸 공유하는 블로그입니다!

    티스토리툴바