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 相关文章推荐
js实现幻灯片播放图片示例代码
Nov 07 Javascript
js实现跟随鼠标移动且带关闭功能的图片广告实例
Feb 26 Javascript
JavaScript动态插入CSS的方法
Dec 10 Javascript
分离与继承的思想实现图片上传后的预览功能:ImageUploadView
Apr 07 Javascript
AngularJS中一般函数参数传递用法分析
Nov 22 Javascript
通过BootStrap-select插件 js jQuery控制select属性变化
Jan 03 Javascript
JS将unicode码转中文方法
May 08 Javascript
一次Webpack配置文件的分离实战记录
Nov 30 Javascript
layui checkbox默认选中,获取选中值,清空所有选中项的例子
Sep 02 Javascript
微信小程序实现吸顶特效
Jan 08 Javascript
javascript中的offsetWidth、clientWidth、innerWidth及相关属性方法
May 14 Javascript
JS 4个超级实用的小技巧 提升开发效率
Oct 05 Javascript
详解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代码
2011/11/27 PHP
php中的观察者模式简单实例
2015/01/20 PHP
csdn 论坛技术区平均给分功能
2009/11/07 Javascript
jquery isType() 类型判断代码
2011/02/14 Javascript
最常用的12种设计模式小结
2011/08/09 Javascript
兼容主流浏览器的iframe自适应高度js脚本
2014/01/10 Javascript
js检测输入内容全为空格的方法
2014/05/03 Javascript
javascript实现rgb颜色转换成16进制格式
2015/07/10 Javascript
jQuery纵向导航菜单效果实现方法
2016/12/19 Javascript
JavaScript中数组Array.sort()排序方法详解
2017/03/01 Javascript
基于vue的fullpage.js单页滚动插件
2017/03/20 Javascript
axios进阶实践之利用最优雅的方式写ajax请求
2017/12/20 Javascript
解决vue prop传值default属性如何使用,为何不生效的问题
2020/09/21 Javascript
如何使用RoughViz可视化Vue.js中的草绘图表
2021/01/30 Vue.js
[04:45]上海特级锦标赛主赛事第三日TOP10
2016/03/05 DOTA
[37:45]完美世界DOTA2联赛PWL S3 LBZS vs Phoenix 第二场 12.09
2020/12/11 DOTA
python选择排序算法实例总结
2015/07/01 Python
Python可变参数函数用法实例
2015/07/07 Python
Python文件常见操作实例分析【读写、遍历】
2018/12/10 Python
详解Python 重学requests发起请求的基本方式
2020/02/07 Python
python剪切视频与合并视频的实现
2020/03/03 Python
opencv python在视屏上截图功能的实现
2020/03/05 Python
html5+css3气泡组件的实现
2014/11/21 HTML / CSS
HTML 5 input placeholder 属性如何完美兼任ie
2014/05/12 HTML / CSS
英国豪华家具和经典家居饰品购物网站:OKA
2020/06/05 全球购物
英国时尚首饰品牌:Missoma
2020/06/29 全球购物
初婚未育未抱养证明
2014/01/12 职场文书
2014年大班元旦活动方案
2014/02/26 职场文书
优秀党务工作者事迹材料
2014/05/07 职场文书
平安家庭示范户事迹
2014/06/02 职场文书
机关作风建设自查报告
2014/10/22 职场文书
销售经理工作检讨书
2015/02/19 职场文书
大学生英文求职信范文
2015/03/19 职场文书
python中print格式化输出的问题
2021/04/16 Python
python神经网络学习 使用Keras进行回归运算
2022/05/04 Python
windows10 家庭版下FTP服务器搭建教程
2022/08/05 Servers