js实现磁性吸附的示例
磁性吸附
【js实现磁性吸附的示例】目录
- 代码实例
- 与限定范围拖拽的差异
- 下载源码链接
* { padding: 0; margin: 0; }#box1 { width: 500px; height: 500px; background: #999; position: relative; left: 100px; top: 100px; }#box { width: 100px; height: 100px; background: #334; position: absolute; cursor: move; }(function () { var dragging = false var boxX, boxY, mouseX, mouseY, offsetX, offsetY var box = document.getElementById('box') var box1 = document.getElementById('box1') // 鼠标按下的动作 box.onmousedown = down // 鼠标的移动动作 document.onmousemove = move // 释放鼠标的动作 document.onmouseup = up // 鼠标按下后的函数,e为事件对象 function down(e) { dragging = true // 获取元素所在的坐标 boxX = box.offsetLeft boxY = box.offsetTop // 获取鼠标所在的坐标 mouseX = parseInt(getMouseXY(e).x) mouseY = parseInt(getMouseXY(e).y) // 鼠标相对元素左和上边缘的坐标 offsetX = mouseX - boxX offsetY = mouseY - boxY } // 鼠标移动调用的函数 function move(e){ if (dragging) {// 获取移动后的元素的坐标var x = getMouseXY(e).x - offsetXvar y = getMouseXY(e).y - offsetY// 计算可移动位置的大小, 保证元素不会超过可移动范围// 此处就是父元素的宽度减去子元素宽度var width = box1.clientWidth - box.offsetWidthvar height = box1.clientHeight - box.offsetHeight// min方法保证不会超过右边界,max保证不会超过左边界x = Math.min(Math.max(0, x), width)y = Math.min(Math.max(0, y), height)// 磁性吸附部分if (x < RANGE) {x = 0}if (width - x < RANGE) {x = width}if (y < RANGE) {y = 0}if (height - y < RANGE) {y = height}// 给元素及时定位box.style.left = x + 'px'box.style.top = y + 'px' } } // 释放鼠标的函数 function up(e){ dragging = false } // 函数用于获取鼠标的位置 function getMouseXY(e){ var x = 0, y = 0 e = e || window.event if (e.pageX) {x = e.pageXy = e.pageY } else {x = e.clientX + document.body.scrollLeft - document.body.clientLefty = e.clientY + document.body.scrollTop - document.body.clientTop } return {x: x,y: y } }})()
与限定范围拖拽的差异
简易拖拽的链接
限定范围拖拽的链接
添加磁性吸附部分
// 磁性吸附部分if (x < RANGE) {x = 0}if (width - x < RANGE) {x = width}if (y < RANGE) {y = 0}if (height - y < RANGE) {y = height}
下载源码链接
星辉的Github
以上就是js实现磁性吸附的示例的详细内容,更多关于js实现磁性吸附的资料请关注脚本之家其它相关文章!
推荐阅读
- React|React UI组件库——如何快速实现antd的按需引入和自定义主题
- 自定义持久层框架MyORMFramework—框架实现
- 如何实现随叫随到的客户服务
- 基于ABP实现DDD--领域服务、应用服务和DTO实践
- 机器学习图像处理|从零开始实现一个简单的CycleGAN项目
- unity3d|Unity3D实现3D立体游戏原理及过程
- SAP|SAP 电商云 Spartacus UI SiteContextUrlParams 的实现明细介绍
- Angular|Angular 依赖注入机制实现原理的深入介绍
- iOS实现简单长截图
- 数据结构-js实现-栈