<MyRusakov.ru />

Программирование на JavaScript с Нуля до Гуру 2.0

Программирование на JavaScript с Нуля до Гуру 2.0

Данный курс научит Вас программировать на языке JavaScript, который крайне желательно знать любому уважающему себя программисту. Курс состоит из 8 разделов, в которых Вы с нуля освоите этот язык и сможете создавать самые разные программы для самых разных задач любой сложности. В курсе Вы получите всю необходимую теоретическую часть, а также увидите массу практических примеров, в том числе, и из моей практики.

Дополнительно, почти к каждому уроку идут упражнения.

Помимо самого курса Вас ждёт ещё 5 бесплатных ценных Бонусов: «Библиотека jQuery», «Защита JavaScript-кода от копирования», «Решение упражнений из курса», «HTML для начинающих» и «CSS для начинающих».

Подробнее
Подписка

Подписавшись по E-mail, Вы будете получать уведомления о новых статьях.

Подписка Подписаться

Добавляйтесь ко мне в друзья ВКонтакте! Отзывы о сайте и обо мне оставляйте в моей группе.

Мой аккаунт Мой аккаунт Моя группа
Опрос

Каким движком Вы предпочитаете пользоваться?

События Drag-and-Drop в JS

События Drag-and-Drop в JS

На данном уроке мы познакомимся с технологией Drag-and-Drop, дословный перевод тяни и бросай. Задача реализуется путем захвата элемента и перемещения его в другое место или бросания на другой элемент.


Draggable элемент + область

Мы будем перетаскивать блок elem на блок area. Чтобы сделать блок перетаскиваемым, ему нужно добавить атрибут draggable="true". В этом легко можно убедиться, если захватить блок мышкой и потянуть за него, то создастся полупрозрачная копия.


События Drag-and-Drop в JS.

// HTML
<div class="elem" draggable="true">тяни</div>
<div class="area">бросай</div>

// CSS
.elem {
    width: 150px;
    height: 150px;
    background: plum;
    margin: 40px auto;
    text-align: center;
    line-height: 150px;
}

.area {
    width: 200px;
    height: 200px;
    border: 10px solid plum;
    margin: 10px auto;
    padding: 10px;
}

Рассмотрим все события, которые могут происходить при Drag-and-Drop. Получим оба элемента и присвоим их переменным.

// JavaScript
let elem = document.querySelector('.elem');
let area = document.querySelector('.area');

События для перетаскиваемого объекта
  • dragstart
  • dragend
  • drag

Dragstart

Событие dragstart возникает в момент начала захвата элемента. Слушатель addEventListener отлавливает событие dragstart и запускается функция, которая выводит в консоли слово Start.

elem.addEventListener('dragstart', function() {
    console.log('Start');
});

События Drag-and-Drop в JS.

Dragend

Событие dragend возникает в момент отпускания элемента.

elem.addEventListener('dragend', function() {
    console.log('End');
});

Drag

Событие drag возникает в состоянии перетягивания, даже если элемент просто зажат мышкой и никуда не двигается.

elem.addEventListener('drag', function() {
    console.log('Drag');
});

События Drag-and-Drop в JS.

События для принимающего объекта
  • dragenter
  • dragleave
  • dragover
  • drop

Dragenter

Событие dragenter наступает при заходе курсора перетаскиваемого элемента на принимающий блок.

area.addEventListener('dragenter', function() {
console.log('Enter');
});

События Drag-and-Drop в JS.

Dragleave

Событие dragleave наступает когда перетаскиваемый элемент покидает целевой блок.

area.addEventListener('dragleave', function() {
    console.log('Leave');
});

События Drag-and-Drop в JS.

Dragover

Событие dragover наступает в процессе движения перемещаемого элемента внутри целевого.

area.addEventListener('dragover', function() {
    event.preventDefault();
    console.log('Over');
});

События Drag-and-Drop в JS.

Drop

Событие drop наступает, когда мы отпускаем элемент при одном условии, что у события dragover должен быть прописан метод preventDefault(). С помощью метода appendChild() добавим один элемент в конец другого.

area.addEventListener('drop', function(event) {
    console.log('Drop');
    this.appendChild(elem);
});

События Drag-and-Drop в JS.

Копирование материалов разрешается только с указанием автора (Михаил Русаков) и индексируемой прямой ссылкой на сайт (http://myrusakov.ru)!

Добавляйтесь ко мне в друзья ВКонтакте: http://vk.com/myrusakov.
Если Вы хотите дать оценку мне и моей работе, то напишите её в моей группе: http://vk.com/rusakovmy.

Если Вы не хотите пропустить новые материалы на сайте,
то Вы можете подписаться на обновления: Подписаться на обновления

Если у Вас остались какие-либо вопросы, либо у Вас есть желание высказаться по поводу этой статьи, то Вы можете оставить свой комментарий внизу страницы.

Порекомендуйте эту статью друзьям:

Если Вам понравился сайт, то разместите ссылку на него (у себя на сайте, на форуме, в контакте):

  1. Кнопка:

    Она выглядит вот так: Как создать свой сайт

  2. Текстовая ссылка:

    Она выглядит вот так: Как создать свой сайт

  3. BB-код ссылки для форумов (например, можете поставить её в подписи):

Комментарии (0):

Для добавления комментариев надо войти в систему.
Если Вы ещё не зарегистрированы на сайте, то сначала зарегистрируйтесь.