JavaScript to achieve simple drag effect

JavaScript to achieve simple drag effect

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:
  • JQuery Dialog (JS modal window, draggable DIV)
  • Analysis of how to use Sortable.js drag and drop sorting
  • js to achieve drag effect
  • JavaScript implements touch screen drag function on mobile terminal
  • Simple drag effect implemented using js
  • JS realizes beautiful window drag effect (can change size, maximize, minimize, close)
  • Example of file drag and drop upload function implemented by JS
  • Using javascript to implement mouse drag events
  • JS component Bootstrap Table table row drag effect implementation code
  • JS implements the touch screen drag function on mobile devices

<<:  HTML code that can make IE freeze

>>:  Teach you to connect to MySQL database using eclipse

Recommend

Solution to the failure of docker windows10 shared directory mounting

cause When executing the docker script, an error ...

React realizes the whole process of page watermark effect

Table of contents Preface 1. Usage examples 2. Im...

In-depth understanding of slot-scope in Vue (suitable for beginners)

There are already many articles about slot-scope ...

The easiest way to install MySQL 5.7.20 using yum in CentOS 7

The default database of CentOS7 is mariadb, but m...

Connector configuration in Tomcat

JBoss uses Tomcat as the Web container, so the co...

How to implement line breaks in textarea text input area

If you want to wrap the text in the textarea input...

The difference and usage of LocalStorage and SessionStorage in vue

Table of contents What is LocalStorage What is Se...

Native js canvas to achieve a simple snake

This article shares the specific code of js canva...

Learn about JavaScript closure functions in one article

Table of contents Variable Scope The concept of c...

Detailed explanation of the functions of each port of Tomcat

From the tomcat configuration file, we can see th...

Detailed tutorial on deploying Apollo custom environment with docker-compose

Table of contents What is the Apollo Configuratio...

Installation, activation and configuration of ModSecurity under Apache

ModSecurity is a powerful packet filtering tool t...

Summary of basic knowledge and operations of MySQL database

This article uses examples to explain the basic k...

MySQL Router implements MySQL read-write separation

Table of contents 1. Introduction 2. Configure My...