바닐라 ★append 많이 쓰인다★
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>Title</title> <style> .box { margin-top: 10px; border: 1px solid black; padding: 10px; } </style> </head> <body> <h1>추가하기</h1> <button onclick="addAppend()">append로 추가하기</button> <button onclick="addPrepend()">prepend로 추가하기</button> <button onclick="addBefore()">before로 추가하기</button> <button onclick="addAfter()">after로 추가하기</button> <div class="box" id="outerBox"> </div> <script> function addAppend() { let newEl = document.createElement("div"); newEl.setAttribute("class", "box"); newEl.setAttribute("id", "innerBox1"); //id, innerBox1 속성을 줬으니, 애는 이제 id innerBox1이다. (자세한 설명은 아래에) newEl.innerHTML = "내부박스1"; let el = document.querySelector("#outerBox"); el.append(newEl); } function addPrepend() { let newEl = document.createElement("div"); newEl.setAttribute("class", "box"); newEl.setAttribute("id", "innerBox2"); newEl.innerHTML = "내부박스2"; let el = document.querySelector("#outerBox"); el.prepend(newEl); } function addBefore() { let newEl = document.createElement("div"); newEl.setAttribute("class", "box"); newEl.setAttribute("id", "innerBox3"); newEl.innerHTML = "내부박스3"; let el = document.querySelector("#outerBox"); el.before(newEl); } function addAfter() { let newEl = document.createElement("div"); newEl.setAttribute("class", "box"); newEl.setAttribute("id", "innerBox4"); newEl.innerHTML = "내부박스4"; let el = document.querySelector("#outerBox"); el.after(newEl); } </script> </body> </html>
data:image/s3,"s3://crabby-images/ae0d7/ae0d74665d3fcec4f4c02f712754750a698ec0d1" alt="notion image"
//id 하나 추가 된 모습! id를 동적으로 만들어냄
data:image/s3,"s3://crabby-images/af01e/af01e15b6a0ffe056c0e93a4771ad12794f8ae2b" alt="notion image"
setAttribute를 사용해 자바 스크립트로 동적으로 만들어내기
data:image/s3,"s3://crabby-images/3961e/3961e119857768b3910766369e3204bfb56f93d6" alt="notion image"
이 2개의 코드는 다르다. console 확인 ㄱㄱ
data:image/s3,"s3://crabby-images/14ab8/14ab8041d035cfe51d8c266468927f586462a7c0" alt="notion image"
1. 자바 스크립트가 인식하는 DOM 객체 2. 그냥 문자열
data:image/s3,"s3://crabby-images/bf5f9/bf5f994028cb501ae1767bd4667fc29b355b5d23" alt="notion image"
data:image/s3,"s3://crabby-images/bd22a/bd22a9b3dc95c4d0fb548e1e9690170bcd9df86b" alt="notion image"
setAttribute("class", "box"); 이렇게 코드를 작성하면, 아까 봤던 '순수한 div'에 클래스가 붙을 것이다. (콘솔창에서 봐야함)
attribute (속성)은 바로 이런 걸 말한다. class, id 이런 것!
data:image/s3,"s3://crabby-images/1f6be/1f6be2b7a86735c8251e53b0b6e110436273d81b" alt="notion image"
data:image/s3,"s3://crabby-images/5cf74/5cf74573f4d62bdd2cd0b75f574dc8fea7f02d1c" alt="notion image"
data:image/s3,"s3://crabby-images/7fac3/7fac3cbda12874f94e5d66af40d8fa89b0c7af8d" alt="notion image"
이렇게 작성하면 이 코드의 attribute가 2개 추가 될 것이다 -> 이런 것들을 자바 스크립트로 동적으로 만들어낼 수 있구나!
객체의 상태 = 속성 (attribute)
html의 <div> 태그에 어떤 속성들이 있어?
data:image/s3,"s3://crabby-images/cf284/cf284c320a7ce9a57f10a06df874968787dfcb43" alt="notion image"
이런 것들을 엘레멘트.클래스 이런 식으로 해서 찾을 수 있겠구나
data:image/s3,"s3://crabby-images/1de0b/1de0b75379a0b404b59afde97818d9f0cc05fa0c" alt="notion image"
이런 것들을 물어보면서.... vs 코드에서 공부해보자!
innerHTML / innerText
data:image/s3,"s3://crabby-images/8302b/8302bc28ad2e42e56d4f5dba8b615b133b225cc6" alt="notion image"
innerHTML은 HTML 코드 인식 O innerText는 HTML 코드 인식 X -> 쓸 일 잘 없음
data:image/s3,"s3://crabby-images/7a749/7a74954871e0591fda28597d9256ee24987930c4" alt="notion image"
//innerHTML
data:image/s3,"s3://crabby-images/146a7/146a704ee08e330e0abb5abc4854105277508e54" alt="notion image"
//innerText → HTML 코드 인식 안 되고 TEXT로 인식 됐다!
val() (input 태그에 사용)
자바 스크립트로 하면 이런 풀코드가 필요하네… jQuery로 바꿔보자!
jQuery로 변경 하자
[ 추가하기 코드 ]
<script> function addAppend() { // let newEl = document.createElement("div"); // console.log(newEl); // console.log("<div></div"); // newEl.setAttribute("class", "box"); // newEl.setAttribute("id", "innerBox1"); // newEl.innerHTML = "내부박스1"; // let el = document.querySelector("#outerBox"); // el.append(newEl); let newString = `<div class="box" id="innerBox">내부박스</div>`; $("#outerBox").append(newString); }
[ jQuery로 바꿨을 때, 실행 화면 ]
data:image/s3,"s3://crabby-images/38e39/38e39fa0ec85d41a93e521a96c1ee8667e6f18b2" alt="notion image"
[ 이렇게 사용하면 좋은 점 ]
data:image/s3,"s3://crabby-images/e74aa/e74aaa0a1814627f936d752f3fe3db02f80c64ba" alt="notion image"
디자인을 자바 스크립트 function에 넣어놓고 땡겨쓸 수 있음! -> 재사용 가능!
그러나!! id가 중복되는 문제 발생!
그러나!! id가 유일하지 않은 문제가 있다. id가 유일하지 않으면 삭제하고 싶은 특정한 엘리먼트를 찾을 수가 없어서 삭제를 못함
<script> let n = 1; function addAppend() { let newString = `<div class="box" id="innerBox1${n}">내부박스${n}</div>`; n++; $("#outerBox").append(newString); }
data:image/s3,"s3://crabby-images/4040c/4040cb35dab4da54d9db76af537ff7c14ac85787" alt="notion image"
id 값이 다 다르게 나오는 것 확인! → 바꿔보자! → DOM 삭제하기 (전역변수 이용)
id는 유일해야한다!
Share article