HTML5 - Glisser-déposer

Drag and Drop (DnD) est un puissant concept d'interface utilisateur qui facilite la copie, la réorganisation et la suppression d'éléments à l'aide de clics de souris. Cela permet à l'utilisateur de cliquer et de maintenir le bouton de la souris enfoncé sur un élément, de le faire glisser vers un autre emplacement et de relâcher le bouton de la souris pour y déposer l'élément.

Pour obtenir la fonctionnalité de glisser-déposer avec HTML4 traditionnel, les développeurs devraient soit utiliser une programmation JavaScript complexe, soit d'autres frameworks JavaScript tels que jQuery, etc.

Maintenant, HTML 5 est venu avec une API de glisser-déposer (DnD) qui apporte la prise en charge native de DnD au navigateur, ce qui facilite beaucoup le codage.

HTML 5 DnD est pris en charge par tous les principaux navigateurs tels que Chrome, Firefox 3.5 et Safari 4, etc.

Glisser-déposer des événements

Un certain nombre d'événements sont déclenchés au cours des différentes étapes de l'opération de glisser-déposer. Ces événements sont listés ci-dessous -

N ° Sr. Événements et description
1

dragstart

Se déclenche lorsque l'utilisateur commence à faire glisser l'objet.

2

dragenter

Déclenché lorsque la souris est déplacée pour la première fois sur l'élément cible alors qu'un glissement se produit. Un écouteur pour cet événement doit indiquer si une suppression est autorisée sur cet emplacement. S'il n'y a pas d'écouteurs ou si les écouteurs n'effectuent aucune opération, une suppression n'est pas autorisée par défaut.

3

dragover

Cet événement est déclenché lorsque la souris est déplacée sur un élément lorsqu'un glissement se produit. La plupart du temps, l'opération qui se produit pendant un écouteur sera la même que l'événement dragenter.

4

dragleave

Cet événement est déclenché lorsque la souris quitte un élément pendant qu'un glissement se produit. Les auditeurs doivent supprimer tous les marqueurs de surlignage ou d'insertion utilisés pour les commentaires de suppression.

5

drag

Se déclenche à chaque fois que la souris est déplacée pendant que l'objet est déplacé.

6

drop

L'événement de dépôt est déclenché sur l'élément où le dépôt a eu lieu à la fin de l'opération de glissement. Un auditeur serait chargé de récupérer les données glissées et de les insérer à l'emplacement de dépôt.

sept

dragend

Se déclenche lorsque l'utilisateur relâche le bouton de la souris tout en faisant glisser un objet.

Note- Notez que seuls les événements de glissement sont déclenchés; les événements de souris tels que mousemove ne sont pas déclenchés pendant une opération de glissement.

L'objet DataTransfer

Les méthodes d'écoute d'événements pour tous les événements de glisser-déposer acceptent Event objet qui a un attribut en lecture seule appelé dataTransfer.

le event.dataTransfer Retour DataTransfer objet associé à l'événement comme suit -

function EnterHandler(event) {
   DataTransfer dt = event.dataTransfer;
   .............
}

L' objet DataTransfer contient des données sur l'opération de glisser-déposer. Ces données peuvent être récupérées et définies en termes de divers attributs associés à l'objet DataTransfer comme expliqué ci-dessous -

N ° Sr. Attributs DataTransfer et leur description
1

dataTransfer.dropEffect [ = value ]

  • Renvoie le type d'opération actuellement sélectionné.

  • Cet attribut peut être défini pour modifier l'opération sélectionnée.

  • Les valeurs possibles sont none, copy, link et move.

2

dataTransfer.effectAllowed [ = value ]

  • Renvoie les types d'opérations à autoriser.

  • Cet attribut peut être défini pour modifier les opérations autorisées.

  • Les valeurs possibles sont none, copy, copyLink, copyMove, link, linkMove, move, all et uninitialized.

3

dataTransfer.types

Renvoie une DOMStringList répertoriant les formats définis dans l'événement dragstart. De plus, si des fichiers sont glissés, l'un des types sera la chaîne "Fichiers".

4

dataTransfer.clearData ( [ format ] )

Supprime les données des formats spécifiés. Supprime toutes les données si l'argument est omis.

5

dataTransfer.setData(format, data)

Ajoute les données spécifiées.

6

data = dataTransfer.getData(format)

Renvoie les données spécifiées. S'il n'y a pas de telles données, renvoie la chaîne vide.

sept

dataTransfer.files

Renvoie une FileList des fichiers en cours de glissement, le cas échéant.

8

dataTransfer.setDragImage(element, x, y)

Utilise l'élément donné pour mettre à jour les commentaires de glissement, en remplaçant tous les commentaires précédemment spécifiés.

9

dataTransfer.addElement(element)

Ajoute l'élément donné à la liste des éléments utilisés pour rendre le retour de glissement.

Processus de glisser-déposer

Voici les étapes à suivre pour implémenter l'opération de glisser-déposer -

Étape 1 - Rendre un objet déplaçable

Voici les étapes à suivre -

  • Si vous souhaitez faire glisser un élément, vous devez définir le draggable attribuer à true pour cet élément.

  • Définir un écouteur d'événements pour dragstart qui stocke les données glissées.

  • L'auditeur d'événement dragstart définira les effets autorisés (copie, déplacement, lien ou une combinaison).

Voici l'exemple pour rendre un objet déplaçable -

<!DOCTYPE HTML>

<html>
   <head>
      
      <style type = "text/css">
         
         #boxA, #boxB {
            float:left;padding:10px;margin:10px; -moz-user-select:none;
         }
         #boxA { background-color: #6633FF; width:75px; height:75px;  }
         #boxB { background-color: #FF6699; width:150px; height:150px; }
      </style>
      
      <script type = "text/javascript">
         
         function dragStart(ev) {
            ev.dataTransfer.effectAllowed = 'move';
            ev.dataTransfer.setData("Text", ev.target.getAttribute('id'));
            ev.dataTransfer.setDragImage(ev.target,0,0);
            
            return true;
         }
      </script>
      
   </head>
   <body>
      
      <center>
         <h2>Drag and drop HTML5 demo</h2>
         <div>Try to drag the purple box around.</div>
         
         <div id = "boxA" draggable = "true" 
            ondragstart = "return dragStart(ev)">
            <p>Drag Me</p>
         </div>
         
         <div id = "boxB">Dustbin</div>
      </center>
      
   </body>
</html>

Cela produira le résultat suivant -

Étape 2 - Déposer l'objet

Pour accepter un dépôt, la cible de dépôt doit écouter au moins trois événements.

  • le dragenterévénement, qui est utilisé pour déterminer si la cible de dépôt doit accepter ou non la suppression. Si la dépose doit être acceptée, cet événement doit être annulé.

  • le dragoverévénement, qui est utilisé pour déterminer quel retour d'information doit être montré à l'utilisateur. Si l'événement est annulé, le retour (généralement le curseur) est mis à jour en fonction de la valeur de l'attribut dropEffect.

  • Finalement, le drop événement, qui permet d'effectuer la suppression réelle.

Voici l'exemple pour déposer un objet dans un autre objet -

<html>
   <head>
      <style type="text/css">
         #boxA, #boxB {
            float:left;padding:10px;margin:10px;-moz-user-select:none;
         }
         #boxA { background-color: #6633FF; width:75px; height:75px;  }
         #boxB { background-color: #FF6699; width:150px; height:150px; }
      </style>
      <script type="text/javascript">
         function dragStart(ev) {
            ev.dataTransfer.effectAllowed='move';
            ev.dataTransfer.setData("Text", ev.target.getAttribute('id'));
            ev.dataTransfer.setDragImage(ev.target,0,0);
            return true;
         }
         function dragEnter(ev) {
            event.preventDefault();
            return true;
         }
         function dragOver(ev) {
            return false;
         }
         function dragDrop(ev) {
            var src = ev.dataTransfer.getData("Text");
            ev.target.appendChild(document.getElementById(src));
            ev.stopPropagation();
            return false;
         }
      </script>
   </head>
   <body>
      <center>
         <h2>Drag and drop HTML5 demo</h2>
         <div>Try to move the purple box into the pink box.</div>
         <div id="boxA" draggable="true" ondragstart="return dragStart(event)">
            <p>Drag Me</p>
         </div>
         <div id="boxB" ondragenter="return dragEnter(event)" ondrop="return dragDrop(event)" ondragover="return dragOver(event)">Dustbin</div>
      </center>
   </body>
</html>

Cela produira le résultat suivant -