首页 > 作文

实现元素拖拽的两种方式

更新时间:2023-04-07 04:05:36 阅读: 评论:0

  第一种方式:使用h5的api datatransfer

  实现思路:

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

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

  代码如下:

<html>希特勒 中国;<head>    <meta chart="utf-8">    <style>        .box1 {            width: 100px;            height: 100px;            border: 1px black solid;            margin-bottom: 20px;            background: lightblue;        }        .box2 {            width: 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.tdata("text", e.target.id);        }    </script></body></ht一度电等于多少千瓦时ml>

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

  思路:

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

<html><head>    <meta chart="utf-8">    <style> 奶茶妹妹走红照片       .box1 {            width: 100px;            height: 100px;            border: 1px black solid;            margin-bottom: 20px;            background: lightblue;        }        .box2 {            width: 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.querylector("#drag");//获取操作元素        drag.onmoudown = function (e) {//鼠标按下触发            var disx = e.pagex - drag.offtleft;//获取鼠标相对元素距离            var disy = e.pagey - drag.offttop;            console.log(e.pagex);            console.log(drag.offtleft);            document.onmoumove = function (e) {//鼠标移动触发事件,元素移到对应为位置                drag.style.left = e.pagex - disx + 'px';                drag.style.top = e.pagey - disy + 'px';            }            document.onmouup = function(){//鼠标抬起,清除绑定的事件,元素放置在对应的位置 三个月宝宝腹泻               document.onmoumove = null;                document.onmoudown = null;            };            e.preventdefault();//阻止浏览器的默认事件        };    </script&端午放假2020gt;</body></html>

本文发布于:2023-04-07 04:05:34,感谢您对本站的认可!

本文链接:https://www.wtabcd.cn/fanwen/zuowen/5444ca74124ccd35704ee5a0b8e9d672.html

版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系,我们将在24小时内删除。

本文word下载地址:实现元素拖拽的两种方式.doc

本文 PDF 下载地址:实现元素拖拽的两种方式.pdf

标签:元素   鼠标   我是   事件
相关文章
留言与评论(共有 0 条评论)
   
验证码:
Copyright ©2019-2022 Comsenz Inc.Powered by © 专利检索| 网站地图