js实现拖拽元素选择和删除
程序员文章站
2022-06-23 08:04:42
本文实例为大家分享了js实现拖拽元素选择和删除的具体代码,供大家参考,具体内容如下我们上网的时候讲过一些平台在选择一些选项的时候采用拖拽的方式将选项拖入指定位置完成选择,现在我们就自己来实现一下类似的...
本文实例为大家分享了js实现拖拽元素选择和删除的具体代码,供大家参考,具体内容如下
我们上网的时候讲过一些平台在选择一些选项的时候采用拖拽的方式将选项拖入指定位置完成选择,现在我们就自己来实现一下类似的效果。
结果如下:
代码如下:
<!doctype html> <html> <head> <meta charset="utf-8" /> <title>js置顶动画</title> <style> *{margin:0;padding:0;user-select:none;} .move-box {height:100px;width:100px;line-height:100px;text-align:center;font-size:14px;background:#ccc;margin:0 auto;position:relative;transition:all .1s;} .drag-box{width:1000px;margin:100px auto;border:1px dashed #ccc;font-size:0;background:url('./img/bg1.png') no-repeat center;background-size:80px;} .drag-box::after{content:'';display:block;clear:both;} /***清浮动***/ .drag-box .label{height:100px;width:0;color:#fff;line-height:0;text-align:center;font-size:14px;display:inline-block;background:blue;} .drag-box .close-btn{padding:2px;margin-left:10px;background:#eee;} </style> </head> <body> <div class="move-box">拖动元素</div> <div class="drag-box"> <div class="label"></div> </div> </body> <script> (function(){ let boxid = 0; let startx = null; let starty = null; let mousex = null; let mousey = null; let mbox = null; function $$(str) {return document.queryselectorall(str);} // 计算鼠标是否在需要放置的框内 function computinele(ele, x, y){ let left = ele.getboundingclientrect().left; let top = ele.getboundingclientrect().top; let width = ele.getboundingclientrect().width; let height = ele.getboundingclientrect().height; let xflag = ( x > left && x < (left + width)); let yflag = ( y > top && y < (top + height)); if (xflag && yflag) { return true; } else { return false; } } // 删除元素 $$('.drag-box')[0].onclick = function(e){ console.log(e); if (e.srcelement.classname == 'close-btn') { this.removechild(e.srcelement.parentnode); settimeout(() => { alert('删除成功!'); }, 0); } } // 鼠标按下复制一个元素 $$('.move-box')[0].onmousedown = function(e){ mousex = e.pagex; mousey = e.pagey; startx = this.getboundingclientrect().left; starty = this.getboundingclientrect().top; console.log(this.getboundingclientrect()); // 复制一个元素追加到body模拟跟随鼠标移动效果 mbox = this.clonenode(true); mbox.style.position = 'fixed'; mbox.style.zindex = '9999'; mbox.style.opacity = '.75'; mbox.style.left = startx + 'px'; mbox.style.top = starty + 'px'; mbox.id = 'movebox' + (boxid++); document.body.appendchild(mbox); document.onmousemove = function(e){ mbox.style.left = startx + (e.pagex - mousex) + 'px'; mbox.style.top = starty + (e.pagey - mousey) + 'px'; }; }; // 鼠标按下放开事件 document.onmouseup = function(e){ let x = e.pagex; let y = e.pagey; let ele = $$('.drag-box')[0]; console.log(computinele(ele, x, y)); if (mbox) { // 松开鼠标时鼠标在拖拽框内,则将复制的元素追加到拖拽框内 if (computinele(ele, x, y)) { mbox.style.position = 'static'; mbox.style.display = 'block'; mbox.style.float = 'left'; mbox.style.margin = 'auto'; mbox.style.opacity = '1'; mbox.innertext = mbox.innertext +(boxid - 1); let close = document.createelement('span'); close.classname = 'close-btn'; close.innertext = '×'; close.title = '删除元素'; mbox.appendchild(close); ele.appendchild(mbox); mbox.onmousedown = null; } else { // 松开鼠标时鼠标不在拖拽框内,移除复制的元素 mbox.style.left = startx + 'px'; mbox.style.top = starty + 'px'; document.body.removechild(document.body.lastelementchild); } startx = null; starty = null; mousex = null; mousey = null; mbox = null; document.onmousemove = null; } }; })(); </script> </html>
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
上一篇: 高质量软文都有哪些特点
下一篇: 软文三要素是什么?如何挖掘软文核心卖点
推荐阅读
-
js实现兼容PC端和移动端滑块拖动选择数字效果
-
JS实现复选框的全选和批量删除功能
-
Android使用CardView作为RecyclerView的Item并实现拖拽和左滑删除
-
经典_用js快速实现鼠标和键盘选择下拉菜单(代码详解)
-
经典_用js快速实现鼠标和键盘选择下拉菜单(代码详解)
-
android的RecyclerView实现拖拽排序和侧滑删除示例
-
RecyclerView进阶:使用ItemTouchHelper实现拖拽和侧滑删除效果
-
Android recyclerview实现拖拽排序和侧滑删除
-
android的RecyclerView实现拖拽排序和侧滑删除示例
-
Android recyclerview实现拖拽排序和侧滑删除