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:
|
<<: Implementation of docker view container log command
>>: HTML table tag tutorial (19): row tag
After entering the Docker container, if you exit ...
Defining an array in Bash There are two ways to c...
Table of contents Method 1: Routing meta informat...
Often you will encounter a style of <a> tag...
Web Services are concerned with application-to-ap...
In MySQL, you may encounter the problem of case s...
Aggregating data from various sources allows the ...
Prepare: Define a teacher table and a student tab...
This article example shares the specific code of ...
Why do we need to summarize the browser compatibi...
This article shares the use of js and jQuery tech...
Some command differences between versions: show i...
Table of contents 1. Check whether the docker env...
js realizes the special effect of clicking and dr...
## 1 I'm learning docker deployment recently,...