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

[JavaScript] DOM( img바꾸기 )

2022. 1. 29. 11:45
728x90

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

<style type="text/css">
	img, #view{
		width: 300px;
		height: 300px;
	}
</style>
<script type="text/javascript">

	function createImg(){
		var radioButton = document.getElementsByName("rdoBtn");
		var radioVal = "";

		for(var i = 0; i < radioButton.length; i++){
			if(radioButton[i].checked){
				radioVal = radioButton[i].value;
			}
		}

		var img = document.createElement("img");
		img.setAttribute("src", "resources/image/"+radioVal);
		
		var div = document.getElementById("view");
		var chd = document.querySelector("#view > img");
		div.replaceChild(img, chd);
	}
	
	function deleteImg(){
		document.getElementById("view").innerHTML = "<img>";
	}
</script>
</head>
<body>

	<input type="radio" name="rdoBtn" value="img01.png">img01<br>
	<input type="radio" name="rdoBtn" value="img02.png">img02<br>
	<input type="radio" name="rdoBtn" value="img03.png">img03<br>
	
	<button onclick="createImg();">이미지 생성</button>
	<button onclick="deleteImg();">이미지 삭제</button>
	
	<div id="view"><img alt="" src=""></div>

</body>
</html>

​

​

​

​

​

​

function createImg(){
	// 1. 이름이 rdoBtn인 요소들을 가지고 온다.
	var radioButton = document.getElementsByName("rdoBtn");
	var radioVal = "";
	// 2. 가져온 요소들을 반복하면서, 체크되어있는 라디오버튼의 value를 가지고온다.
	for(var i = 0; i < radioButton.length; i++){
		if(radioButton[i].checked){
			radioVal = radioButton[i].value;
		}
	}
	// 3. img 태그를 만들어서, "resources/image/"+라디오버튼.value를 널어주자.
	// img 태그 만들기 -> src 속성에다가 위의 결로값 넣어주기
	var img = document.createElement("img");
	img.setAttribute("src", "resources/image/"+radioVal);
		
	// 4. 만들어진 img 태그를 바꿔치기 하자
	var div = document.getElementById("view");
	var chd = document.querySelector("#view > img");
	div.replaceChild(img, chd);
}
 
 

​

​

​

​

function deleteImg(){
	document.getElementById("view").innerHTML = "<img>";
}

이미지 삭제 버튼을 누르면 해당 함수가 실행이됩니다.

이 함수는 view영역에 속성이 아무것도 없는 img를넣어 사진이 없어진것처럼 보이는 효과를 냅니다.

728x90

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

[JavaScript] DOM( 태그 추가하기 / 이동하기 )  (0) 2022.01.31
[JavaScript] DOM( 이미지 속성 변경 )  (0) 2022.01.30
[JavaScript] DOM( createElement / createAttribute )  (0) 2022.01.28
[JavaScript] DOM(parentNode / childNodes)  (0) 2022.01.27
[JavaScript] select(리스트 선택)  (0) 2022.01.26
    'JS 관련/JavaScript' 카테고리의 다른 글
    • [JavaScript] DOM( 태그 추가하기 / 이동하기 )
    • [JavaScript] DOM( 이미지 속성 변경 )
    • [JavaScript] DOM( createElement / createAttribute )
    • [JavaScript] DOM(parentNode / childNodes)
    씨네
    씨네
    개발자 씨네가 공부하는 내용을 기록 겸 공유하는 블로그입니다!

    티스토리툴바