zoukankan      html  css  js  c++  java
  • 实现元素拖拽的两种方式

    第一种方式:使用H5的API dataTransfer

    实现思路:

    1.为将要拖拽的元素设置允许拖拽,并赋予dragstart事件将其id转换成数据保存;

    2.为容器添加dragover属性添加事件阻止浏览器默认事件,允许元素放置,并赋予drop事件进行元素的放置。

    代码如下:

    <html>
    <head>
        <meta charset="utf-8">
        <style>
            .box1 {
                 100px;
                height: 100px;
                border: 1px black solid;
                margin-bottom: 20px;
                background: lightblue;
            }
    
            .box2 {
                 100px;
                height: 100px;
                border: 1px black solid;
                background: lightcoral;
            }
        </style>
    </head>
    
    <body>
        <!-- 参数要传入event对象 -->
        <div class="box1" ondragover="allowdrop(event)" ondrop="drop(event)">
            <img src="img/2.jpg" alt="00" draggable="true" ondragstart="drag(event)" id="drag" width="50" height="50">
            <span>我是盒子一</span>
        </div>
        <div class="box2" ondragover="allowdrop(event)" ondrop="drop(event)">
        <span>我是盒子二</span></div>
        <script>
            function allowdrop(e) {
                e.preventDefault();
            }
    
            function drop(e) {
                e.preventDefault();
                var data = e.dataTransfer.getData("text");
                e.target.appendChild(document.getElementById(data));
            }
    
            function drag(e) {
                e.dataTransfer.setData("text", e.target.id);
            }
        </script>
    </body>
    
    </html>

    广州设计公司https://www.houdianzi.com 我的007办公资源网站https://www.wode007.com

    第二种方式:使用原生js(通过计算元素的位置结合定位实现)

    思路:

    1.获取鼠标距离元素左边界和上边界的距离;
    2.移动后计算出元素相对原来位置的相对距离,赋予样式。

    代码:

    <html>
    <head>
        <meta charset="utf-8">
        <style>
            .box1 {
                 100px;
                height: 100px;
                border: 1px black solid;
                margin-bottom: 20px;
                background: lightblue;
            }
    
            .box2 {
                 100px;
                height: 100px;
                border: 1px black solid;
                background: lightcoral;
            }
    
            #drag {
                position: relative;
            }
        </style>
    </head>
    
    <body>
        <div class="box1" id="drag">
            <span>我是盒子一</span>
        </div>
        <div class="box2">
            <span>我是盒子二</span></div>
        <script>
            let drag = document.querySelector("#drag");//获取操作元素
            drag.onmousedown = function (e) {//鼠标按下触发
                var disx = e.pageX - drag.offsetLeft;//获取鼠标相对元素距离
                var disy = e.pageY - drag.offsetTop;
                console.log(e.pageX);
                console.log(drag.offsetLeft);
                document.onmousemove = function (e) {//鼠标移动触发事件,元素移到对应为位置
                    drag.style.left = e.pageX - disx + 'px';
                    drag.style.top = e.pageY - disy + 'px';
                }
                document.onmouseup = function(){//鼠标抬起,清除绑定的事件,元素放置在对应的位置
                    document.onmousemove = null;
                    document.onmousedown = null;
                };
                e.preventDefault();//阻止浏览器的默认事件
            };
        </script>
    </body>
    
    </html>
  • 相关阅读:
    SpringCloud(一)概念及设计
    SpringBoot2(十三)HttpMessageConverter
    SpringBoot2(十二)当Shiro遇上RedisCache
    SpringBoot2(十一)集成RedisCache
    UDP协议解析 以及和TCP协议的区别
    TCP协议解析及相关问题
    mybatis缓存机制
    MYSQL数据库类型与JAVA类型对应表
    Java HashMap问题
    Java数据库事务四大特性以及隔离级别
  • 原文地址:https://www.cnblogs.com/qianxiaox/p/13841050.html
Copyright © 2011-2022 走看看