JavaScript Crash Course

Робота із DOM в JavaScript

10

Зміст:

  1. Що таке HTML DOM?

  2. Методи DOM

  3. Події (events) DOM

  4. DOM EventListener

  5. Зміна CSS властивостей в DOM

  6. cookie, localStorage та  sessionStorage

Що таке HTML DOM?

The HTML DOM (Document Object Model)

     Коли сторінка завантажується, браузер створює Document Object Model сторінки.

Модель HTML DOM побудована як дерево об’єктів:

HTML DOM

Завдяки об’єктній моделі JavaScript отримує всю необхідну потужність для створення динамічного HTML з використанням JavaScript:

  •  змінювати всі елементи HTML на сторінці
  • змінювати всі атрибути HTML на сторінці
  • змінювати всі стилі CSS на сторінці
  • видаляти наявні елементи та атрибути HTML
  • додавати нові елементи та атрибути HTML
  • реагувати на всі наявні події HTML на сторінці
  • створювати нові події HTML на сторінці

Що таке DOM?

     DOM є стандартом W3C (World Wide Web Consortium).

    Стандарт W3C DOM розділений на 3 різні частини:

  • Core DOM - стандартна модель для всіх типів документів
  • XML DOM - стандартна модель для документів XML
  • HTML DOM - стандартна модель для документів HTML

Що таке HTML DOM?

      HTML DOM — це стандартна об’єктна модель та інтерфейс програмування для HTML. Він визначає:

  • Елементи HTML як об'єкти
  • Властивості всіх елементів HTML
  • Методи доступу до всіх елементів HTML
  • Події для всіх елементів HTML

 

Іншими словами: HTML DOM — це стандарт отримання, зміни, додавання або видалення елементів HTML.

<html>
  <head>
  	<title>My awesome page</title>
  </head>

  <body>
      My awesome content will be here ^-^
  </body>
  
</html>

Методи та події(events) DOM

Інтерфейс програмування DOM

     У DOM усі елементи HTML визначені як об’єкти.
      Властивість — це значення, яке можна отримати або встановити (наприклад, змінити вміст елемента HTML).
      Метод — це дія, яку можна виконати (наприклад, додати або видалити елемент HTML).

Об'єкт document 

     Об'єкт document представляє веб-сторінку. Якщо потрібно отримати доступ до будь-якого елемента на сторінці HTML,  починаємо з доступу до об’єкта document.

Знаходженян елементу: document.getElementById()

<html>
  <body>

    <p id="demo"></p>

   <script>
     let demoElement = document.getElementById("demo");
     demoElement.innerHTML = "Hello World!";
   </script>

  </body>
</html>

     Метод, що дозволяє знайти HTML елемент за його id.

Знаходженян елементу: document.getElementsByTagName(name)

<html>
  <body>

    <p id="demo"></p>

   <script>
     let demoElement = document.getElementsByTagName("P")[0];
     demoElement.innerHTML = "Hello World!";
   </script>

  </body>
</html>

     Метод, що дозволяє знайти всі HTML елементи на сторінці за назвою тега.

Знаходженян елементу: document.getElementsByClassName(className)

<html>
  <body>

    <p id="demo"></p>
    <p class="topic"></p>
    <p class="result"></p>

   <script>
    const topicElement = document.getElementsByClassName('topic')[0];
    topicElement.innerHTML = "New topic for the next demo";

   </script>

  </body>
</html>

     Метод, що дозволяє знайти всі HTML елементи на сторінці за назвою класу.

Знаходженян елементу: document.querySelector(className/id)

<html>
  <body>

    <p id="demo"></p>
    <p class="topic"></p>
    <p class="result"></p>

   <script>
    const resultElement = document.querySelector('.result');
    resultElement.innerHTML = "The demo result";
     
    //const resultElement = document.querySelector('#demo-result');

   </script>

  </body>
</html>

    Метод, що дозволяє знайти всі HTML елемент на сторінці за назвою класу або id.

Зміна властивостей елемента

Зміна властивостей елемента: element.attribute

<html>
  <body>

    <p id="demo"></p>
    <p class="topic"></p>
    <p id="demo-result" class="result"></p>

    <label for="feedback"> Feedback </label><br>
    <textarea id="feedback" value="" rows="6" cols="30"></textarea>

   <script>
    const demoElement = document.getElementsByTagName('P')[0];
    demoElement.innerHTML = 'Hello World!';

    document.getElementById('feedback').value = 'Add feedback...';
 
   </script>

  </body>
</html>

Зміна властивостей елементу: element.style.property

<html>
  <body>

    <p id="demo"></p>
    <p class="topic"></p>
    <p class="result"></p>

   <script>
    const body = document.querySelector('body');
    body.style.backgroundColor = '#232323';
    body.style.color = '#fff';
     
    const demoElement = document.getElementsByTagName('P')[0];
    demoElement.innerHTML = 'Hello World!';
    
    const topicElement = document.getElementsByClassName('topic')[0];
    topicElement.innerHTML = 'New topic for the next demo';

    const resultElement = document.querySelector('#demo-result');
    resultElement.innerHTML = 'The demo result';
   </script>

  </body>
</html>

Маніпуляції з елементами

  В об'єкті document також достпуні методи для створення, додавання, видалення і заміни HTML елементів.

Маніпуляції з елементами: document.createElement(element)

<html>
  <body>

    <p id="demo"></p>

   <script>
     const div = document.createElement('div');
     div.innerHTML = 'I am created div element.';
     
    const img = document.createElement('img');
    img.src = 'https://static.vecteezy.com/system/resources/thumbnails/000/629/035/small/MADE_IN_UKRAINE.jpg';

   </script>

  </body>
</html>

    Метод, що дозволяє створити необхідний HTML елемент за назвою тега.

Маніпуляції з елементами: document.appendChild(element)

<html>
  <body>
   <p id="demo"></p>
   <script>
     const div = document.createElement('div');
     div.innerHTML = 'I am created div element.';
     
     const img = document.createElement('img');
     img.src = 'https://static.vecteezy.com/system/resources/thumbnails/000/629/035/small/MADE_IN_UKRAINE.jpg';
    
     // first, we can add img to the div
     div.append(img);
     // then we can add them to the p with #demo 
     document.getElementById('demo').appendChild(div)

   </script>

  </body>
</html>

    Метод, що дозволяє додати створений HTML елемент на сторінці біля потрібного елемента.

Маніпуляції з елементами: document.removeChild(element)

<html>
  <body>
   <p id="demo"></p>
   <span id="removable">Topic</span>
   <script>
     const body = document.querySelector('body');
     const removableElement = document.getElementById('removable');
	 body.removeChild(removableElement);

   </script>

  </body>
</html>

    Метод, що дозволяє видалити  існуючий HTML елемент із сторінки.


Зміна CSS властивостей в DOM 

HTML

CSS

Основні стилі DOM елементів

  • display

  • width, height

  • position

  • padding, margin

  • border

  • color, background

  • font

  • box-sizing

  • transform, z-index

  • transition, animation

 

Зміна стилів

Щоб змінити CSS стилі у потрібно елемента, потрібно використовувати наступний синтаксис:

 

document.getElementById(id).style.property = new style

Зміна кольрів HTML елемента

<html>
  <body>

    <form></form>

    <button id="submit" class="btn-submit"> Submit </button> 

    <script>
      const btn = document.getElementById("submit");
      
      btn.style.backgroundColor = 'black';
      btn.style.color = 'white';

    </script>

  </body>
</html>

DOM EventListener

HTML

CSS

JavaScript

DOM Events

      Події HTML DOM дозволяють з допомогою JavaScript зареєструвати різних обробників подій для елементів. Використовуються в поєднанні з функціями, код в яких буде виконуватися тільки після взаємодії із елементом.

const btn = document.getElementById("submit-btn");
const callback = (e) => { console.log(e)};

btn.addEventListener('click', callback);

знаходження елемента

метод для відслідковування подій

елемент

callback функція

назва події

функція, яка буде викликана

Приклад із кнопкою

<html>
  <head><title>My App</title></head>
  <body>
    <select>
      <option>LOTR</option>
      <option>Back to the Future</option>
    </select>
    
    <button id="vote"> Vote </button> 

  </body>
  <script>
    const btn = document.getElementById("vote");

    const showAlert = () => {
      alert("Button is clicked");
    };

    btn.addEventListener('click', showAlert);
  </script>  
</html>

Типи подій: mouse events

Event

Опис

  click

  натискання на елемент

  mouseover

  наведення на елемент

  mouseout

  покидає елемент

  mousedown

  натисканні клавішою мишки на елемент

  mouseup

  відпускання клавіші мишки над елементом

  mousemove

  при русі курсора

Типи подій: mouse events

<html>
  <head><title>My App</title></head>
 
  <body>
    <button id="login">Login</button> 
  </body>

  <script>
    const btn = document.getElementById("login");

    // hover event
    btn.addEventListener('mouseover', () => {
      console.log('Would you like to login?');
    });
	// click event
    btn.addEventListener('click', () => {
      console.log('Trying to login...');
    });
  </script>  
</html>

Типи подій: keyboard events

Event

Опис

  keydown

  натискання клавіш клавіатури

  keyup

  відпускання клавіш клавіатури


<html>
  <head><title>My webpage</title></head>
  <body>

    <form>
        <label for="bio"> Feedback </label><br>
        <textarea id="bio" value="" rows="6" cols="30"></textarea>
        <br/>
        <label for="feedback"> Feedback </label><br>
        <textarea id="feedback" value="" rows="6" cols="30"></textarea>
    </form>

   <script>
        const bio = document.getElementById('bio');
        bio.addEventListener('keyup', e => console.log('keyup ', e));

     	const feedback = document.getElementById('feedback');
        feedback.placeholder = 'Add feedback...';
        
        feedback.addEventListener('keydown', e => console.log('keydown ', e));

   </script>

  </body>
</html>

keyboard events: keydown & keyup

Типи подій: form events

Event

Опис

  focus

  фокус на елементі форми

  submit

 подання форми

  blur

  зміна фокусу з елементу форми

  change

  зміна значеннь в елементах форми

<html>
  <head><title>My webpage</title></head>
  <body>

    <form>
        <label for="feedback"> Feedback </label><br>
        <textarea id="feedback" value="" rows="6" cols="30"></textarea>
    </form>

   <script>
     	const feedback = document.getElementById('feedback');
        feedback.placeholder = 'Add feedback...';

        feedback.addEventListener('change', e => console.log(e));    
   </script>

  </body>
</html>

form event: change (event listener)

<html>
  <head><title>My webpage</title></head>
  <body>

    <form id="feedback-form">
        <label for="name"> Name </label><br>
        <input id="name" value="" />
        <br/>
 
        <label for="feedback"> Feedback </label><br>
        <textarea id="feedback" value="" rows="6" cols="30"></textarea>

        <br/>
        <button type="submit">Submit</button>
    </form>

   <script>
     	const form = document.getElementById('feedback-form');

         form.addEventListener('submit', e => {
            e.preventDefault();
            console.log(e);
        });
   </script>

  </body>
</html>

form event: submit (event listener)

Типи подій: window/document events

Event

Опис

  load

  завантаження сторінки

  unload

 покидання веб-сторінки

  resize

  зміна розміру вікна браузера

<html>
  <body>

    <form><input id="name" placeholder="Enter your name" /></form>

    <button id="submit" class="btn-submit"> Submit </button> 

    <script>
      window.addEventListener('load', (event) => {
        console.log('page is fully loaded');
        
        const btn = document.getElementById("submit");
      
        btn.style.backgroundColor = 'black';
        btn.style.color = 'white';
      });   

    </script>

  </body>
</html>

window event: load (event listener)

<html>
  <body>

    <form><input id="name" placeholder="Enter your name" /></form>

    <button id="submit" class="btn-submit"> Submit </button> 

    <script>
      window.onload  = (event) => {
        console.log('page is fully loaded');
        
        const btn = document.getElementById("submit");
      
        btn.style.backgroundColor = 'black';
        btn.style.color = 'white';
      };   

    </script>

  </body>
</html>

window event: onload (event handler)

 

cookie, localStorage та  sessionStorage

cookie

       cookie (англ. Cookie - печиво) - невеликий фрагмент даних, відправлений веб-сервером, який зберігається в браузері користувача. Браузер при кожному запиту пересилає цей фрагмент даних веб-сервера в складі HTTP-запиту. На практиці зазвичай використовується для:

  • аутентифікації користувача

  • зберігання персональних налаштувань та конфігурацій

  • відстеження стану сеансу доступу користувача

  • ведення статистики про користувачів

Запис та доступ до cookie

document.cookie = "favorite_food=icecream;expires=2019-02-25T13:16:05.000Z";
document.cookie = "favorite_movie=LOTR";

const getCookie = function(name) {
    const result = document.cookie.match("\\b" + name + "=([^;]*)\\b");
 
    return result ? result[1] : null;
}

getCookie('favorite_movie'); // LOTR

localStorage && sessionStorage

    За допомогою веб-сховища веб-додатки можуть зберігати дані локально в браузері користувача. Веб-сховище є більш безпечним, і великі обсяги даних можуть зберігатися локально, localStorage & sessionStorage дозволяють зберігати набагато більше даних (принаймні 5 МБ), а інформація ніколи не передається на сервер.

Усі сторінки, з одного домену, можуть зберігати й отримувати доступ до тих самих даних.

  • window.localStorage - "живуть" безкінечно довго,

  • window.sessionStorage - "живуть" протягом сесії.

localStorage

// add value with key "name"
localStorage.setItem("name", "Tom");

// read value by key "name"
localStorage.getItem("name");

// remove value by key "name"
localStorage.removeItem("name");

sessionStorage

// add value with key "lastName"
sessionStorage.setItem("lastName", "Doe");

// read value with key "lastName"
sessionStorage.getItem("lastName");

Q & A

_12 JavaScript Crash Course

By Inna Ivashchuk

_12 JavaScript Crash Course

  • 339