


HTML5 drag and drop operation HTML5 implements drag and drop operation of web page elements_html5 tutorial skills
Before HTML5, to implement the drag-and-drop operation of web page elements, you needed to rely on mousedown, mousemove, mouseup and other APIs, which were implemented through a large amount of JS code; HTML5 introduced APIs that directly support drag-and-drop operations, which greatly simplified web page elements It is difficult to program drag-and-drop operations, and these APIs not only support drag-and-drop of elements within the browser, but also support mutual dragging of data between the browser and other applications.
This article uses a simple example to demonstrate the use of drag-and-drop API in HTML5.
Scene:
As shown in the figure below, we want to achieve:
Drag the photo from the "Album" area on the left to the "Trash" area on the right by dragging and dropping; during the dragging process, the "Warm Tips" section should remind you that the drag-and-drop operation is currently in progress;
Implementation method:
The HTML code of the above interface is relatively simple, as follows:
Warm reminder: You can drag the photo directly to the trash can
Album



Trash
Note: If you want to implement drag and drop operation, You need to add the draggable="true" attribute to the element to be dragged and dropped;
Next, just add the following JS code to the onload event. The comments are quite detailed and will not be explained separately.
<script><br> function init(){<br> var info = document.getElementById("info");<br> //Get the dragged and dropped element, this example is where the photo album is DIV<br> var src = document.getElementById("album");<br> //Start drag and drop operation<br> src.ondragstart = function (e) {<br> //Get the ID of the dragged and dropped photo <br> var dragImgId = e.target.id;<br> //Get the dragged element<br> var dragImg = document.getElementById(dragImgId);<br> //Drag and drop operation ends<br> dragImg.ondragend = function(e){<br> //Restore reminder information<br> info.innerHTML="<h2>Warm reminder: You can drag the photo directly to the trash can</h2>";<br> }; <br> e.dataTransfer.setData("text",dragImgId);<br> };<br> //During drag and drop process <br> src.ondrag = function(e){ <br> info.innerHTML=" <h2>--The photo is being dragged--</h2>";<br> }<br> //Get the drag and drop target element<br> var target = document.getElementById("trash"); <br> //Turn off default processing; <br> target.ondragenter = function(e){<br> e.preventDefault();<br> }<br> target.ondragover = function(e){<br> e .preventDefault(); <br> }<br> //Something is dragged and dropped on the target element <br> target.ondrop = function (e) {<br> var draggedID = e.dataTransfer.getData("text"); <br> //Get the DOM object in the album <br> var oldElem = document.getElementById(draggedID);<br> //Remove the node of the photo from the album DIV <br> oldElem.parentNode.removeChild(oldElem); <br> //Add the dragged photo DOM node to the trash can DIV; <br> target.appendChild(oldElem);<br> info.innerHTML="<h2>Warm tip: You can drag the photo directly To the trash can</h2>";<br> e.preventDefault();<br> }<br> }<br> </script>
to achieve the effect :

Hot AI Tools

Undresser.AI Undress
AI-powered app for creating realistic nude photos

AI Clothes Remover
Online AI tool for removing clothes from photos.

Undress AI Tool
Undress images for free

Clothoff.io
AI clothes remover

AI Hentai Generator
Generate AI Hentai for free.

Hot Article

Hot Tools

Notepad++7.3.1
Easy-to-use and free code editor

SublimeText3 Chinese version
Chinese version, very easy to use

Zend Studio 13.0.1
Powerful PHP integrated development environment

Dreamweaver CS6
Visual web development tools

SublimeText3 Mac version
God-level code editing software (SublimeText3)

Hot Topics

The article discusses using viewport meta tags to control page scaling on mobile devices, focusing on settings like width and initial-scale for optimal responsiveness and performance.Character count: 159

This article details creating interactive HTML5 games using JavaScript. It covers game design, HTML structure, CSS styling, JavaScript logic (including event handling and animation), and audio integration. Essential JavaScript libraries (Phaser, Pi

This article explains how to create and validate HTML5 forms. It details the <form> element, input types (text, email, number, etc.), and attributes (required, pattern, min, max). The advantages of HTML5 forms over older methods, incl

This article explains how to embed audio in HTML5 using the <audio> element, including best practices for format selection (MP3, Ogg Vorbis), file optimization, and JavaScript control for playback. It emphasizes using multiple audio f

The article discusses managing user location privacy and permissions using the Geolocation API, emphasizing best practices for requesting permissions, ensuring data security, and complying with privacy laws.

The article discusses using the HTML5 Page Visibility API to detect page visibility, improve user experience, and optimize resource usage. Key aspects include pausing media, reducing CPU load, and managing analytics based on visibility changes.

The article explains how to use the HTML5 Drag and Drop API to create interactive user interfaces, detailing steps to make elements draggable, handle key events, and enhance user experience with custom feedback. It also discusses common pitfalls to a

This article explains the HTML5 WebSockets API for real-time, bidirectional client-server communication. It details client-side (JavaScript) and server-side (Python/Flask) implementations, addressing challenges like scalability, state management, an
