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


Posted in Javascript onAugust 25, 2020

本文实例为大家分享了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>

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
javascript学习笔记(七) js函数介绍
Jun 19 Javascript
JavaScript将Table导出到Excel实现思路及代码
Mar 13 Javascript
关于javascript event flow 的一个bug详解
Sep 17 Javascript
Javascript实现获取及设置光标位置的方法
Jul 21 Javascript
JavaScript如何实现在文本框(密码框)输入提示语
Dec 25 Javascript
etmvc+jQuery EasyUI+combobox多值操作实现角色授权实例
Nov 09 Javascript
Node.js用readline模块实现输入输出
Dec 16 Javascript
BootStrap Table对前台页面表格的支持实例讲解
Dec 22 Javascript
jquery实现超简单的瀑布流布局【推荐】
Mar 08 Javascript
Vue表单验证插件的制作过程
Apr 01 Javascript
详解vue-cli开发环境跨域问题解决方案
Jun 06 Javascript
使用layer弹窗,制作编辑User信息页面的方法
Sep 27 Javascript
基于vue实现简易打地鼠游戏
Aug 21 #Javascript
vue实现打地鼠小游戏
Aug 21 #Javascript
js实现滑动进度条效果
Aug 21 #Javascript
探索浏览器页面关闭window.close()的使用详解
Aug 21 #Javascript
vue组件开发之tab切换组件使用详解
Aug 21 #Javascript
vue组件开发之slider组件使用详解
Aug 21 #Javascript
Vue左滑组件slider使用详解
Aug 21 #Javascript
You might like
用PHP读注册表
2006/10/09 PHP
高亮度显示php源代码
2006/10/09 PHP
php开发过程中关于继承的使用方法分享
2011/06/17 PHP
php时间戳转换的示例
2014/03/31 PHP
PHP Static延迟静态绑定用法分析
2016/03/16 PHP
thinkPHP5.0框架独立配置与动态配置方法
2017/03/17 PHP
再谈IE中Flash控件的自动激活 ObjectWrap
2007/03/09 Javascript
电子商务网站上的常用的js放大镜效果
2011/12/08 Javascript
js弹出层包含flash 不能关闭隐藏的2种处理方法
2013/06/17 Javascript
js在数组中删除重复的元素自保留一个(两种实现思路)
2014/08/22 Javascript
利用jquery操作Radio方法小结
2014/10/20 Javascript
javascript实现图像循环明暗变化的方法
2015/02/25 Javascript
Javascript使用SWFUpload进行多文件上传
2016/11/16 Javascript
vue2利用Bus.js如何实现非父子组件通信详解
2017/08/25 Javascript
react.js 父子组件数据绑定实时通讯的示例代码
2017/09/25 Javascript
基于jsbarcode 生成条形码并将生成的条码保存至本地+源码
2020/04/27 Javascript
vue 调用 RESTful风格接口操作
2020/08/11 Javascript
[01:19:23]2018DOTA2亚洲邀请赛 4.5 淘汰赛 Mineski vs VG 第二场
2018/04/06 DOTA
[49:15]DOTA2-DPC中国联赛 正赛 CDEC vs XG BO3 第二场 1月19日
2021/03/11 DOTA
用python实现对比两张图片的不同
2018/02/05 Python
Pandas之drop_duplicates:去除重复项方法
2018/04/18 Python
python实现关键词提取的示例讲解
2018/04/28 Python
pygame实现简易飞机大战
2018/09/11 Python
Python2和Python3中@abstractmethod使用方法
2020/02/04 Python
基于python实现音乐播放器代码实例
2020/07/01 Python
详解pandas赋值失败问题解决
2020/11/29 Python
Antonioli美国在线商店:时尚前卫奢华
2019/07/29 全球购物
ASICS印度官方网站:日本专业运动品牌
2020/06/20 全球购物
Can a struct inherit from another struct? (结构体能继承结构体吗)
2016/09/25 面试题
简述安装Slackware Linux系统的过程
2012/01/12 面试题
学生档案自我鉴定
2013/10/07 职场文书
工作决心书
2014/03/11 职场文书
追讨欠款律师函
2015/05/27 职场文书
PyQt5 显示超清高分辨率图片的方法
2021/04/11 Python
 Python 中 logging 模块使用详情
2022/03/03 Python
Anaconda安装pytorch和paddle的方法步骤
2022/04/03 Python