Native JS to implement drag position preview

Native JS to implement drag position preview

This article shares with you a small Demo that adds a preview when dragging an element. The effect is as follows:

The following is the code implementation, everyone is welcome to copy, paste and comment.

<!DOCTYPE html>
<html>
 
<head>
    <meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
    <title>Native JS to implement drag position preview</title>
    <style>
        .box {
            position: absolute;
            border: 1px dashed black;
        }
 
        #div1 {
            width: 100px;
            height: 100px;
            background: yellow;
            position: absolute;
        }
    </style>
    <script>
        window.onload = function () {
 
            var oDiv = document.getElementById('div1');
 
            oDiv.onmousedown = function (ev) {
 
                var oEvent = ev || event;
                var disX = oEvent.clientX - oDiv.offsetLeft;
                var disY = oEvent.clientY - oDiv.offsetTop;
 
                //Create a div with a dotted frame
                var oNewDiv = document.createElement('div');
 
                oNewDiv.className = 'box';
                // Subtract the border size to coincide with the original div size oNewDiv.style.width = oDiv.offsetWidth - 2 + 'px';
                oNewDiv.style.height = oDiv.offsetHeight - 2 + 'px';
                oNewDiv.style.left = oDiv.offsetLeft + 'px';
                oNewDiv.style.top = oDiv.offsetTop + 'px';
 
                document.body.appendChild(oNewDiv);
 
                document.onmousemove = function (ev) {
 
                    var oEvent = ev || event;
 
                    oNewDiv.style.left = oEvent.clientX - disX + 'px';
                    oNewDiv.style.top = oEvent.clientY - disY + 'px';
                };
 
                document.onmouseup = function () {
 
                    document.onmousemove = null;
                    document.onmouseup = null;
 
                    oDiv.style.left = oNewDiv.style.left;
                    oDiv.style.top = oNewDiv.style.top;
                    //Remove the dotted box document.body.removeChild(oNewDiv);
                };
            };
        };
    </script>
</head>
 
<body>
    <div id="div1"></div>
</body>
 
</html>

The above is the full content of this article. I hope it will be helpful for everyone’s study. I also hope that everyone will support 123WORDPRESS.COM.

You may also be interested in:
  • JS HTML5 drag and drop upload image preview
  • JS implements three methods of uploading pictures and realizing the preview picture function
  • js to realize image upload and preview function
  • js method to realize the preview of uploaded pictures
  • JS preview image displays local images on the browser
  • js to upload pictures and preview them before uploading
  • Javascript local preview example before uploading image
  • js image preview function before uploading (compatible with all browsers)
  • Easily implement js image preview function
  • Analysis of the principle of picture upload preview using js

<<:  Implementation of docker view container log command

>>:  HTML table tag tutorial (19): row tag

Recommend

Detailed explanation of how to exit Docker container without closing it

After entering the Docker container, if you exit ...

Summary of Creating and Using Array Methods in Bash Scripts

Defining an array in Bash There are two ways to c...

Vue implements two routing permission control methods

Table of contents Method 1: Routing meta informat...

W3C Tutorial (13): W3C WSDL Activities

Web Services are concerned with application-to-ap...

In-depth analysis of the Identifier Case Sensitivity problem in MySQL

In MySQL, you may encounter the problem of case s...

5 Tips for Protecting Your MySQL Data Warehouse

Aggregating data from various sources allows the ...

How to disable foreign key constraint checking in MySQL child tables

Prepare: Define a teacher table and a student tab...

jQuery canvas draws picture verification code example

This article example shares the specific code of ...

Browser compatibility summary of common CSS properties (recommended)

Why do we need to summarize the browser compatibi...

The main differences between MySQL 4.1/5.0/5.1/5.5/5.6

Some command differences between versions: show i...

Detailed steps for installing MinIO on Docker

Table of contents 1. Check whether the docker env...

JS implements click drop effect

js realizes the special effect of clicking and dr...

Solution to the problem that docker nginx cannot be accessed after running

## 1 I'm learning docker deployment recently,...