1. 程式人生 > 程式設計 >js實現拖拽元素選擇和刪除

js實現拖拽元素選擇和刪除

本文例項為大家分享了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,y));
  if (mBox) {
  // 鬆開滑鼠時滑鼠在拖拽框內,則將複製的元素追加到拖拽框內
  if (computInEle(ele,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>

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支援我們。