Home Web Front-end H5 Tutorial HTML5 drag and drop operation HTML5 implements drag and drop operation of web page elements_html5 tutorial skills

HTML5 drag and drop operation HTML5 implements drag and drop operation of web page elements_html5 tutorial skills

May 16, 2016 pm 03:50 PM
drag and drop

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:

Copy the code
The code is as follows:




HTML5 implements drag and drop operation





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.

Copy code
The code is as follows:

<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 :

Statement of this Website
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn

Hot AI Tools

Undresser.AI Undress

Undresser.AI Undress

AI-powered app for creating realistic nude photos

AI Clothes Remover

AI Clothes Remover

Online AI tool for removing clothes from photos.

Undress AI Tool

Undress AI Tool

Undress images for free

Clothoff.io

Clothoff.io

AI clothes remover

AI Hentai Generator

AI Hentai Generator

Generate AI Hentai for free.

Hot Article

R.E.P.O. Energy Crystals Explained and What They Do (Yellow Crystal)
2 weeks ago By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Best Graphic Settings
2 weeks ago By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. How to Fix Audio if You Can't Hear Anyone
2 weeks ago By 尊渡假赌尊渡假赌尊渡假赌

Hot Tools

Notepad++7.3.1

Notepad++7.3.1

Easy-to-use and free code editor

SublimeText3 Chinese version

SublimeText3 Chinese version

Chinese version, very easy to use

Zend Studio 13.0.1

Zend Studio 13.0.1

Powerful PHP integrated development environment

Dreamweaver CS6

Dreamweaver CS6

Visual web development tools

SublimeText3 Mac version

SublimeText3 Mac version

God-level code editing software (SublimeText3)

How do I use viewport meta tags to control page scaling on mobile devices? How do I use viewport meta tags to control page scaling on mobile devices? Mar 13, 2025 pm 08:00 PM

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

How to Create Interactive Games with HTML5 and JavaScript? How to Create Interactive Games with HTML5 and JavaScript? Mar 10, 2025 pm 06:34 PM

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

How to Use HTML5 Forms for User Input? How to Use HTML5 Forms for User Input? Mar 10, 2025 pm 02:59 PM

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

How to Add Audio to My HTML5 Website? How to Add Audio to My HTML5 Website? Mar 10, 2025 pm 03:01 PM

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

How do I handle user location privacy and permissions with the Geolocation API? How do I handle user location privacy and permissions with the Geolocation API? Mar 18, 2025 pm 02:16 PM

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.

How do I use the HTML5 Page Visibility API to detect when a page is visible? How do I use the HTML5 Page Visibility API to detect when a page is visible? Mar 13, 2025 pm 07:51 PM

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.

How do I use the HTML5 Drag and Drop API for interactive user interfaces? How do I use the HTML5 Drag and Drop API for interactive user interfaces? Mar 18, 2025 pm 02:17 PM

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

How do I use the HTML5 WebSockets API for bidirectional communication between client and server? How do I use the HTML5 WebSockets API for bidirectional communication between client and server? Mar 12, 2025 pm 03:20 PM

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

See all articles