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 相关文章推荐
JavaScript 中的replace方法说明
Apr 13 Javascript
javascript 24小时弹出一次的代码(利用cookies)
Sep 03 Javascript
jQuery版Tab标签切换
Mar 16 Javascript
扩展jQuery对象时如何扩展成员变量具体怎么实现
Apr 25 Javascript
javascript实现网页子页面遍历回调的方法(涉及 window.frames、递归函数、函数上下文)
Jul 27 Javascript
使用jQuery在移动页面上添加按钮和给按钮添加图标
Dec 04 Javascript
Immutable 在 JavaScript 中的应用
May 02 Javascript
AngularJS 单元测试(一)详解
Sep 21 Javascript
node.js实现博客小爬虫的实例代码
Oct 08 Javascript
详解vue-cli中配置sass
Jun 21 Javascript
原生JS实现的自动轮播图功能详解
Dec 28 Javascript
vue3.0中的双向数据绑定方法及优缺点
Aug 01 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中的使用情况
2015/11/05 PHP
PHP使用内置函数file_put_contents写入文件及追加内容的方法
2015/12/07 PHP
PHP微信开发之查询城市天气
2016/06/23 PHP
php 多进程编程父进程的阻塞与非阻塞实例分析
2020/02/22 PHP
jQuery ajax dataType值为text json探索分享
2013/09/23 Javascript
使图片旋转的3种解决方案
2013/11/21 Javascript
JavaScript中的数组操作介绍
2014/12/30 Javascript
纯js代码制作的网页时钟特效【附实例】
2016/03/30 Javascript
angular.js + require.js构建模块化单页面应用的方法步骤
2017/07/19 Javascript
javaScript实现滚动条事件详解
2020/03/24 Javascript
微信小程序获取手机号授权用户登录功能
2017/11/09 Javascript
详解Vue + Vuex 如何使用 vm.$nextTick
2017/11/20 Javascript
vue组件实现弹出框点击显示隐藏效果
2020/10/26 Javascript
使用Vue中 v-for循环列表控制按钮隐藏显示功能
2019/04/23 Javascript
在vue项目中 实现定义全局变量 全局函数操作
2020/10/26 Javascript
[03:45]Newbee战队出征西雅图 决战2016国际邀请赛
2016/08/02 DOTA
Python 的内置字符串方法小结
2016/03/15 Python
Python实现的手机号归属地相关信息查询功能示例
2017/06/08 Python
基于Python列表解析(列表推导式)
2018/06/23 Python
Python实现在某个数组中查找一个值的算法示例
2018/06/27 Python
Python3使用Matplotlib 绘制精美的数学函数图形
2019/04/11 Python
Python 运行.py文件和交互式运行代码的区别详解
2019/07/02 Python
使用numpngw和matplotlib生成png动画的示例代码
2021/01/24 Python
Subside Sports德国:足球球衣和球迷商品
2019/06/08 全球购物
Diptyque英国官方网站:源自法国的知名香氛品牌
2019/08/28 全球购物
学生的自我鉴定范文
2013/10/24 职场文书
中文专业毕业生自荐书范文
2014/01/04 职场文书
俞敏洪北大演讲稿
2014/05/22 职场文书
干部对照检查材料范文
2014/08/26 职场文书
司机工作自我鉴定
2014/09/19 职场文书
物业管理委托协议(2篇)
2014/09/23 职场文书
个人作风建设剖析材料
2014/10/11 职场文书
逃课检讨书怎么写
2015/01/01 职场文书
导游词之丽江普济寺
2019/10/22 职场文书
SpringBoot快速入门详解
2021/07/21 Java/Android
我去timi了,一起去timi是什么意思?
2022/04/13 杂记