[HTML][Javascript] JavaScript - DOM 요소의 생성 및 삭제, innerHTML, CSS 스타일 적용, JavaScript 스타일 적용

요소의 생성 및 삭제

 1) 요소의 생성 

메서드 설명
createElement() createElement("div")이면 div 요소를 생성
createTextNode() createTextNode("자바스크립트")이면 "자바스크립트" 텍스트 노드를 생성
appendChild() 요소 A.appendChild(child)일 때 child 요소의 '요소A'의 자식 요소로 만들어 줌

 

 ex) 요소의 생성 

  <body>
    <button id="bt">요소 생성</button>
  </body>
  
  <script>
    window.onload = function () {
      var bt = document.getElementById("bt");
      bt.onclick = createNode;
      function createNode() {
        var div = document.createElement("div");
        var txt = document.createTextNode("div 요소가 생성 되었습니다.");
        div.appendChild(txt);
        document.body.appendChild(div);
      }
    };
  </script>

 

 

 

메서드 설명
setAttribute(속성, 값) 요소의 속성을 설정
getAttribute(속성) 요소의 속성값을 반환
removeAttribute(속성) 요소의 속성을 제거 

 

ex) 요소의 속성(attribute) 추가 

 <body>
    <button id="bt">요소 생성</button>
    <button id="del">속성 제거</button>
  </body>
  
  <script>
    window.onload = function () {
      var bt = document.getElementById("bt");
      var del = document.getElementById("del");

      function createNode() {
        var div = document.createElement("div");
        var a = document.createElement("a");
        var txt = document.createTextNode("윤제니");
        a.appendChild(txt);
        a.setAttribute("href", "https://jenny-daru.tistory.com/");
        a.setAttribute("target", "_blank");
        a.setAttribute("title", "새창");
        div.append(a);
        document.body.appendChild(div);
      }
      bt.onclick = createNode;
      del.onclick = function () {
        var divs = document.getElementsByTagName("div");
        divs.item(0).firstChild.removeAttribute("title");
        //divs[0].firstChild.removeAttribute("title");
      };
    };
  </script>

 

 >> [요소 생성] 버튼을 클릭 시 결과 

 

 

 >> [속성 제거] 버튼을 클릭시 결과

      위의 코드에서 버튼 클릭시 첫번째 div의 "title"의 속성을 제거 하는 함수를 실행 하였기 때문에

      첫번째 div의 "title"의 속성만 제거됨.

 

 

 

속성 설명
innerHTML 문자 방식으로 요소를 생성

ex) innerHTML 속성을 이용하여 요소와 속성을 생성

  <body>
    <button id="bt">요소 생성</button>
    <div id="content"></div>
  </body>
  
  <script>
    window.onload = function () {
      var bt = document.getElementById("bt");
      var content = document.getElementById("content");
      bt.onclick = createNode;
      function createNode() {
        console.log("asdfa");
        content.innerHTML =
          "<a href='https://jenny-daru.tistory.com/' target='_blank' title='새창'>윤제니</a>";
      }
    };
  </script>

 

 

 

2) 요소의 삭제

메서드 설명
removeChild() 요소A.removeChild(child)일 때 요소A의 자식 child를 제거
  <body>
    <button id="bt">요소 제거</button>
    <div id="content">
      <a href="https://jenny-daru.tistory.com/" target="_blank" title="새창">윤제니</a>
    </div>
  </body>
  
  <script>
    window.onload = function () {
      var bt = document.getElementById("bt");
      var content = document.getElementById("content");
      bt.onclick = function () {
        content.removeChild(content.firstChild);
      };
    };
  </script>

 

 >> 기본 화면 

경축! 아무것도 안하여 에스천사게임즈가 새로운 모습으로 재오픈 하였습니다.
어린이용이며, 설치가 필요없는 브라우저 게임입니다.
https://s1004games.com

 

 

 

 >> [요소 제거] 버튼 클릭 시 결과 

 

 

 

JavaScript의 스타일 적용 

  자바스크립트 스타일 형식 

요소.style.속성="속성값"
  • 자바스크립트의 스타일 속성과 CSS의 기본 속성 형식은 같지만 속성에 대한 개별 속성은 다르다.
  • ex) 'border-color'의 경우  => 자바스크립트 스타일 속성에서는 '-'를 사용할 수 없어 'borderColor'와 같이 카멜 기법 사용 
CSS 자바스크립트 스타일
color color
background-color backgroundColor
border-bottom-width borderBottomWidth

 

ex) content1과 content2 

    <p id="content1">내용1</p>
    <p id="content2">내용2</p>

 

>> content1의 style 속성 

    <style>
      #content1 {
        width: 200px;
        height: 200px;
        border: 2px solid red;
        border-bottom-width: 4px;
      }
    </style>

 

>> content2의 style 속성은 자바스크립트로 적용 

  <script>
    window.onload = function () {
      var content = document.getElementById("content2");
      content.style.width = "200px";
      content.style.height = "200px";
      content.style.border = "1px solid blue";
      content.style.borderBottomWidth = "4px";
    };
  </script>

 

 >> 결과

 

 

 [출처] https://jenny-daru.tistory.com/25

 

 

본 웹사이트는 광고를 포함하고 있습니다.
광고 클릭에서 발생하는 수익금은 모두 웹사이트 서버의 유지 및 관리, 그리고 기술 콘텐츠 향상을 위해 쓰여집니다.
번호 제목 글쓴이 날짜 조회 수
478 [HTML, Javascript] JavaScript에 변수가 있는지 확인 졸리운_곰 2022.11.15 193
477 [html, javascript] JavaScript에서 함수가 완료 될 때까지 기다립니다 졸리운_곰 2022.11.15 190
476 [IE javascript to Chrome] A universal createPopup() replacement 졸리운_곰 2022.11.14 127
475 [web개발][javascript] TypeScript 기본 문법 정리 졸리운_곰 2022.11.05 122
474 [HTML/Javascript] indexedDB에 대해 알아보자! file 졸리운_곰 2022.09.15 202
» [HTML][Javascript] JavaScript - DOM 요소의 생성 및 삭제, innerHTML, CSS 스타일 적용, JavaScript 스타일 적용 file 졸리운_곰 2022.09.09 144
472 [HTML] Div 를 새창 팝업으로 띄우기 졸리운_곰 2022.09.09 163
471 [Web Design][웹 디자인] Sass(SCSS) 완전 정복! 졸리운_곰 2022.07.31 279
470 [Apache 운영] 404 에러페이지 전환 How to Redirect 404 to Homepage using .htaccess 졸리운_곰 2022.07.28 229
469 [JWT} [WEB] JWT(Json Web Token)란? 개념 정리 및 예제 file 졸리운_곰 2022.07.15 199
468 [php worldpress] [위 에]wordpress 사용자 암호 화 원리 및 알고리즘 분석 졸리운_곰 2022.04.11 203
467 [HTML 디자인] 웹페이지 가로 모드/세로 모드 인식하기 file 졸리운_곰 2022.02.14 149
466 [node.js 응용] PM2 - Node.js 프로세스 관리 도구 file 졸리운_곰 2021.12.10 229
465 [web개발] [jQuery] Select박스 option 값 선택하기 졸리운_곰 2021.10.20 285
464 [web개발][javascript][JQuery] textarea 값 설정및 값 가져오기 졸리운_곰 2021.10.19 313
463 [web개발][javascript] javascript - 주소의 파라미터값 변수로 받기 졸리운_곰 2021.10.19 147
462 [node.js][nodejs] [Linux] 리눅스 내 Node.js 및 NPM 최신 버전으로 유지하기 file 졸리운_곰 2021.10.11 208
461 [javascript][jquery] jQuery 이벤트 중복 방지 - jQuery에서 이벤트 핸들러를 제거하는 가장 좋은 방법은 무엇입니까? 졸리운_곰 2021.09.07 117
460 [javascript] How to append HTML code to a div using JavaScript ? file 졸리운_곰 2021.09.07 119
459 [javascript][jQuery] 제이쿼리(jQuery) 선택자 - #1 file 졸리운_곰 2021.09.07 233
대표 김성준 주소 : 경기 용인 분당수지 U타워 등록번호 : 142-07-27414
통신판매업 신고 : 제2012-용인수지-0185호 출판업 신고 : 수지구청 제 123호 개인정보보호최고책임자 : 김성준 sjkim70@stechstar.com
대표전화 : 010-4589-2193 [fax] 02-6280-1294 COPYRIGHT(C) stechstar.com ALL RIGHTS RESERVED