当前位置: 移动技术网 > IT编程>开发语言>JavaScript > js实现拖拽元素选择和删除

js实现拖拽元素选择和删除

2020年08月22日  | 移动技术网IT编程  | 我要评论
本文实例为大家分享了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>

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持移动技术网。

如您对本文有疑问或者有任何想说的,请点击进行留言回复,万千网友为您解惑!

相关文章:

验证码:
移动技术网