This article shares the specific code of JavaScript to achieve a simple drag effect for your reference. The specific content is as follows 1. Build the scaffolding first: * { margin: 0; padding: 0; } p { background: skyblue; text-align: center; } html, body { width: 100%; height: 100%; } .mask { width: 100%; height: 100%; position: fixed; left: 0; top: 0; background: rgba(0, 0, 0, .5); display: none; } .login { width: 400px; height: 300px; background: purple; position: absolute; left: 50%; top: 50%; transform: translate(-50%, -50%); display: none; cursor: move; } .login>span { display: inline-block; width: 50px; height: 50px; background: red; position: absolute; top: 0; right: 0; } <p>I am a p tag</p> <a href="http://www.baidu.com" >Official website</a> <div class="mask"></div> <div class="login"> <span></span> </div> 2. Logical part //1. Get the element to be operated const oP = document.querySelector("p"); const oMask = document.querySelector(".mask"); const oLogin = document.querySelector(".login"); const oClose = oLogin.querySelector(".login>span"); // console.log(oClose); //2. Listen for click events oP.onclick = function() { oMask.style.display = "block"; oLogin.style.display = "block"; }; oClose.onclick = function() { oMask.style.display = "none"; oLogin.style.display = "none"; }; //3. Listen for the press and move events of the login box oLogin.onmousedown = function(e) { e = e || e.window; //1. Calculate the fixed distance const x = e.pageX - oLogin.offsetLeft; const y = e.pageY - oLogin.offsetTop; // console.log(x); //2. Listen for mobile events oLogin.onmousemove = function(e) { e = e || e.window; //3. Calculate the offset after moving let offsetX = e.pageX - x; let offsetY = e.pageY - y; //4. Reset the position of the login box oLogin.style.left = offsetX + 'px'; oLogin.style.top = offsetY + 'px'; }; }; oLogin.onmouseup = function() { oLogin.onmousemove = null; }; 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:
|
<<: HTML code that can make IE freeze
>>: Teach you to connect to MySQL database using eclipse
cause When executing the docker script, an error ...
Table of contents Preface 1. Usage examples 2. Im...
There are already many articles about slot-scope ...
The default database of CentOS7 is mariadb, but m...
JBoss uses Tomcat as the Web container, so the co...
If you want to wrap the text in the textarea input...
Table of contents What is LocalStorage What is Se...
1. Configure Docker remote connection port Locate...
This article shares the specific code of js canva...
Table of contents Variable Scope The concept of c...
From the tomcat configuration file, we can see th...
Table of contents What is the Apollo Configuratio...
ModSecurity is a powerful packet filtering tool t...
This article uses examples to explain the basic k...
Table of contents 1. Introduction 2. Configure My...