Przejdź do treści

Przeciągnij i upuść <... draggable>

W jaki sposób zablokować przeciąganie elementów myszką?

  • Elementy bez znacznika zamykającego (np. IMG):
    <element draggable="przeciąganie">
  • Elementy ze znacznikiem zamykającym (np. A):
    <element draggable="przeciąganie">...</element>
element
Dowolny znacznik HTML 4.01 lub HTML5
przeciąganie
Może przyjąć jedną z następujących wartości:
  • true - element można przeciągnąć myszką.
  • false - element nie może zostać przeciągnięty.

Pozwalają sterować mechanizmem przeciągnij-i-upuść (ang. drag-and-drop). Zwykle polega on na wskazaniu przeciąganego elementu myszką, wciśnięciu i przytrzymaniu przycisku myszki, przeniesieniu elementu w inne miejsce i zwolnieniu przycisku myszki.

Chociaż do realizacji mechanizmu przeciągnij-i-upuść na stronach WWW zwykle konieczna jest znajomość języka JavaScript, to atrybut ten może być przydatny nawet w czystym HTML. Niektóre elementy każdej strony - jak np. odnośniki hipertekstowe - domyślnie mogą być przeciągane przez użytkowników. Jeśli taki link zostanie upuszczony na pasku adresu przeglądarki, nastąpi jego wczytanie. Można je również upuszczać na pola tekstowe formularzy. W niektórych przypadkach możemy jednak nie chcieć takiego zachowania. Aby zablokować przypadkowe przeciągnięcie elementu przez użytkownika wystarczy nadać mu atrybut draggable="false".

Oprócz tego do sterowania mechanizmem przeciągnij-i-upuść służą zdarzenia:

  • ondragstart - zapoczątkowanie operacji przeciągania
  • ondrag - kontynuacja operacji przeciągania
  • ondragenter - przeciągnięcie obiektu ponad element, gdzie może zostać on upuszczony
  • ondragexit, ondragleave - przeciągnięcie obiektu z elementu, gdzie mógł on być upuszczony
  • ondragover - przeciąganie elementu ponad obiektem, gdzie może on zostać upuszczony
  • ondrop, ondragend - zwolnienie przycisku myszki podczas operacji przeciągania

Pytania i odpowiedzi <div draggable>

Co oznacza przeciąganie w HTML?

Przeciąganie w HTML odnosi się do funkcji przeciągania i upuszczania, która pozwala użytkownikom przenosić elementy z jednego miejsca do innego na stronie internetowej. Dzięki zastosowaniu API Drag and Drop, można oznaczyć elementy jako przeciągane za pomocą atrybutu draggable="true", a następnie obsługiwać zdarzenia takie jak dragstart, dragover, i drop, aby określić, co powinno się stać podczas przeciągania i upuszczania tych elementów.

Jak działa przeciąganie i upuszczanie kodu HTML?

Przeciąganie i upuszczanie w HTML jest obsługiwane przez API Drag and Drop, które umożliwia użytkownikom przeciąganie elementów z jednego miejsca i upuszczanie ich w innym. Do implementacji wykorzystuje się zdarzenia takie jak dragstart, dragover, i drop. Przykład prostego kodu: <div draggable="true" ondragstart="event.dataTransfer.setData('text/plain', event.target.id)" id="dragItem">Przeciągnij mnie</div> <div ondragover="event.preventDefault()" ondrop="handleDrop(event)" id="dropZone">Upuść tutaj</div>.

Jak umieścić przeciąganie w HTML?

Aby umożliwić przeciąganie elementu w HTML, należy ustawić atrybut draggable="true" na elemencie, który ma być przeciągany, oraz obsłużyć zdarzenia dragstart, dragover, i drop. Na przykład: <div draggable="true" ondragstart="event.dataTransfer.setData('text/plain', event.target.id)" id="dragItem">Przeciągnij mnie</div><div ondragover="event.preventDefault()" ondrop="handleDrop(event)" id="dropZone">Upuść tutaj</div>.

Przeglądarki


Chrome

Firefox

Edge

Opera

Safari
draggable4
2010-01-25
2
2006-10-24
12
2015-07-29
12
2012-06-14
5
2010-06-07

Komentarze

Zobacz więcej komentarzy

Facebook