js实现单元格拖拽效果


Posted in Javascript onFebruary 10, 2020

本文实例为大家分享了js实现单元格拖拽效果的具体代码,供大家参考,具体内容如下

<head>
 <meta charset="UTF-8">
 <title></title>
 <style type="text/css">
 * {
  margin: 0;
  padding: 0;
 }
 
 #box {
  position: relative;
 }
 
 #box div {
  position: absolute;
  width: 100px;
  height: 100px;
  border-radius: 15px;
  text-align: center;
  line-height: 100px;
  font-size: 50px;
  cursor: pointer;
 }
 </style>
</head>

<body>
 <div id="box"></div>
 <script type="text/javascript">
 //生成结构
 var oDiv = document.getElementById("box");
 var ml = mt = 10;
 //行列结构
 for(var i = 0; i < 3; i++) { //行
  for(var j = 0; j < 3; j++) { //列
  var aDiv = document.createElement("div");
  oDiv.appendChild(aDiv);
  aDiv.style.left = j * (aDiv.offsetWidth + ml) + "px";
  aDiv.style.top = i * (aDiv.offsetHeight + mt) + "px";

  //背景颜色随机
  aDiv.style.backgroundColor = "rgb(" + Math.floor(Math.random() * 256) + "," + Math.floor(Math.random() * 256) + "," + Math.floor(Math.random() * 256) + ")"; //256=(256-0+1)+0;
  }
 }
 //添加文字
 var str = "ABCDEFGHI";
 var aItems = oDiv.children;
 for(var i = 0; i < str.length; i++) {
  aItems[i].innerText = str[i];
 }
 //拖拽
 for(var i = 0; i < aItems.length; i++) {
  aItems[i].onmousedown = function(e) {
  var evt = e || event;
  var x = evt.offsetX;
  var y = evt.offsetX;
  var dragNode = this;

  var cloneNode = dragNode.cloneNode();
  oDiv.replaceChild(cloneNode, dragNode);
  cloneNode.style.border = "1px dashed #ccc";
  oDiv.appendChild(dragNode);
  dragNode.style.zIndex = 1;

  document.onmousemove = function(e) {
   var evt = e || event;
   var _left = evt.clientX - x;
   var _top = evt.clientY - y;

   dragNode.style.left = _left + "px";
   dragNode.style.top = _top + "px";

   return false; //选中,文字也会拖动 去除默认行为
  }
  document.onmouseup = function() {
   var disArr =[];
   var newArr =[];
   for(var i = 0; i < aItems.length-1; i++) {
   var disx = dragNode.offsetLeft - aItems[i].offsetLeft;
   var disy = dragNode.offsetTop - aItems[i].offsetTop;
   var dis= Math.sqrt(Math.pow(disx, 2) + Math.pow(disy, 2));
    disArr.push(dis);
   newArr.push(dis);
   }

   disArr.sort(function(a, b) {
   return a - b;
   });
   var minval = disArr[0];
   
   var minIndex = newArr.indexOf(minval);

   dragNode.style.left = aItems[minIndex].style.left;
   dragNode.style.top = aItems[minIndex].style.top;
   aItems[minIndex].style.left = cloneNode.style.left;
   aItems[minIndex].style.top = cloneNode.style.top;
   
   oDiv.removeChild(cloneNode);
   
   document.onmousemove = null;
   document.onmouseup = null;

  }
  return false;
  }
 }
 </script>
</body>

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

Javascript 相关文章推荐
使用phantomjs进行网页抓取的实现代码
Sep 29 Javascript
Node.js和MongoDB实现简单日志分析系统
Apr 25 Javascript
在for循环中length值是否需要缓存
Jul 27 Javascript
JS+CSS实现美化的下拉列表框效果
Aug 11 Javascript
全面接触神奇的Bootstrap导航条实战篇
Aug 01 Javascript
Bootstrap 模态框实例插件案例分析
Dec 28 Javascript
jquery 手势密码插件
Mar 17 Javascript
详解使用路由延迟加载 Angular 模块
Oct 12 Javascript
JS实现给数组对象排序的方法分析
Jun 24 Javascript
微信小程序中为什么使用var that=this
Aug 27 Javascript
原生javascript单例模式的应用实例分析
Feb 23 Javascript
vue组件冲突之引用另一个组件出现组件不显示的问题
Apr 13 Vue.js
详解Vue template 如何支持多个根结点
Feb 10 #Javascript
JavaScript canvas动画实现时钟效果
Feb 10 #Javascript
JavaScript canvas仿代码流瀑布
Feb 10 #Javascript
Vue数字输入框组件使用方法详解
Feb 10 #Javascript
JavaScript canvas实现跟随鼠标事件
Feb 10 #Javascript
JavaScript实现简易聊天对话框(加滚动条)
Feb 10 #Javascript
node.js使用 http-proxy 创建代理服务器操作示例
Feb 10 #Javascript
You might like
php并发加锁示例
2016/10/17 PHP
CI框架(CodeIgniter)公共模型类定义与用法示例
2017/08/10 PHP
PHP自动识别当前使用移动终端
2018/05/21 PHP
js变量、作用域及内存详解
2014/09/23 Javascript
ECHO.js 纯javascript轻量级延迟加载的实例代码
2016/05/24 Javascript
jQuery 全选 全部选 反选 实现代码
2016/08/17 Javascript
JavaScript对象创建模式实例汇总
2016/10/03 Javascript
整理一些最近经常遇到的前端面试题
2017/04/25 Javascript
利用js给datalist或select动态添加option选项的方法
2018/01/25 Javascript
vue.js template模板的使用(仿饿了么布局)
2018/08/13 Javascript
vue中轮训器的使用
2019/01/27 Javascript
JS/jQuery实现简单的开关灯效果【案例】
2019/02/19 jQuery
vue-week-picker实现支持按周切换的日历
2019/06/26 Javascript
[01:05:12]2014 DOTA2国际邀请赛中国区预选赛 TongFu VS CIS-GAME
2014/05/21 DOTA
pygame学习笔记(6):完成一个简单的游戏
2015/04/15 Python
python创建和删除目录的方法
2015/04/29 Python
一个基于flask的web应用诞生 组织结构调整(7)
2017/04/11 Python
python实现淘宝秒杀脚本
2020/06/23 Python
python数据预处理 :数据共线性处理详解
2020/02/24 Python
python 图像插值 最近邻、双线性、双三次实例
2020/07/05 Python
HTML5 Plus 实现手机APP拍照或相册选择图片上传功能
2016/07/13 HTML / CSS
Bootstrap 学习分享
2012/11/12 HTML / CSS
AmazeUI 加载进度条的实现示例
2020/08/20 HTML / CSS
Bobbi Brown芭比波朗美国官网:化妆师专业彩妆保养品品牌
2016/08/18 全球购物
土木工程师岗位职责
2013/11/24 职场文书
函授教育个人学习的自我评价
2013/12/31 职场文书
2014基层党员干部学习全国两会心得体会
2014/03/17 职场文书
计算机应用专业毕业生求职信
2014/06/03 职场文书
幼儿园六一活动总结
2014/08/27 职场文书
党员领导干部民主生活会批评与自我批评发言
2014/09/28 职场文书
2015年汽车销售经理工作总结
2015/04/27 职场文书
学校捐款活动总结
2015/05/09 职场文书
2016年中秋节慰问信
2015/12/01 职场文书
幽默口才训练经典句子(48句)
2019/08/19 职场文书
Mysql实现主从配置和多主多从配置
2021/06/02 MySQL
使用Redis实现点赞取消点赞的详细代码
2022/03/20 Redis