js实现磁性吸附的示例


Posted in Javascript onOctober 26, 2020

磁性吸附

目录

  • 代码实例
  • 与限定范围拖拽的差异
  • 下载源码链接  

代码实例

* {
 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;
}

<div id="box1">
<div id="box"></div>
</div>

(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 - offsetX
  var y = getMouseXY(e).y - offsetY

  // 计算可移动位置的大小, 保证元素不会超过可移动范围
  // 此处就是父元素的宽度减去子元素宽度
  var width = box1.clientWidth - box.offsetWidth
  var 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.pageX
  y = e.pageY
 } else {
  x = e.clientX + document.body.scrollLeft - document.body.clientLeft
  y = 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实现磁性吸附的资料请关注三水点靠木其它相关文章!

Javascript 相关文章推荐
jQuery的each终止或跳过示例代码
Dec 12 Javascript
node.js使用nodemailer发送邮件实例
Mar 10 Javascript
javascript数组详解
Oct 22 Javascript
快速解决js动态改变dom元素属性后页面及时渲染的问题
Jul 06 Javascript
angular实现IM聊天图片发送实例
May 08 Javascript
详解axios在vue中的简单配置与使用
May 10 Javascript
angular $watch 一个变量的变化(实例讲解)
Aug 02 Javascript
JavaScript实现左侧菜单效果
Dec 14 Javascript
JavaScript文本特效实例小结【3个示例】
Dec 22 Javascript
javascript设计模式 ? 装饰模式原理与应用实例分析
Apr 14 Javascript
jQuery 移除事件的方法
Jun 20 jQuery
vue中data里面的数据相互使用方式
Jun 05 Vue.js
如何构建一个Vue插件并生成npm包
Oct 26 #Javascript
解决vscode进行vue格式化,会自动补分号和双引号的问题
Oct 26 #Javascript
vue实现前端列表多条件筛选
Oct 26 #Javascript
vue实现单一筛选、删除筛选条件
Oct 26 #Javascript
vue通过接口直接下载java生成好的Excel表格案例
Oct 26 #Javascript
基于elementUI竖向表格、和并列的案例
Oct 26 #Javascript
原生js实现贪吃蛇游戏
Oct 26 #Javascript
You might like
下载文件的点击数回填
2006/10/09 PHP
php中获取远程客户端的真实ip地址的方法
2011/08/03 PHP
利用浏览器的Javascript控制台调试PHP程序
2014/01/08 PHP
thinkphp备份数据库的方法分享
2015/01/04 PHP
Firefox 无法获取cssRules 的解决办法
2006/10/11 Javascript
JavaScript 一道字符串分解的题目
2011/08/03 Javascript
js操作label给label赋值及取label的值示例
2013/11/07 Javascript
js和css写一个可以自动隐藏的悬浮框
2014/03/05 Javascript
jquery css 设置table的奇偶行背景色示例
2014/06/03 Javascript
基于Node.js实现nodemailer邮件发送
2016/01/26 Javascript
Node.js中Request模块处理HTTP协议请求的基本使用教程
2016/03/31 Javascript
js精准的倒计时函数分享
2016/06/29 Javascript
基于JavaScript实现购物车功能
2017/02/07 Javascript
jQuery实现给input绑定回车事件的方法
2017/02/09 Javascript
mui上拉加载功能实例详解
2017/04/13 Javascript
JavaScript中undefined和null的区别
2017/05/03 Javascript
Vue中 v-if 和v-else-if页面加载出现闪现的问题及解决方法
2018/10/12 Javascript
JavaScript设计模式之观察者模式与发布订阅模式详解
2020/05/07 Javascript
Vue中用JSON实现刷新界面不影响倒计时
2020/10/26 Javascript
vue router返回到指定的路由的场景分析
2020/11/10 Javascript
python实现2014火车票查询代码分享
2014/01/10 Python
10款最好的Web开发的 Python 框架
2015/03/18 Python
Python使用迭代器打印螺旋矩阵的思路及代码示例
2016/07/02 Python
python 实现红包随机生成算法的简单实例
2017/01/04 Python
python 定义给定初值或长度的list方法
2018/06/23 Python
Python面向对象基础入门之编码细节与注意事项
2018/12/11 Python
Anaconda之conda常用命令介绍(安装、更新、删除)
2019/10/06 Python
numpy.array 操作使用简单总结
2019/11/08 Python
python模拟预测一下新型冠状病毒肺炎的数据
2020/02/01 Python
关于Python Tkinter Button控件command传参问题的解决方式
2020/03/04 Python
Alexandre Birman美国官网:亚历山大·伯曼
2019/10/30 全球购物
学习党的群众路线教育实践活动心得体会
2014/03/01 职场文书
企业管理毕业生求职信
2014/03/11 职场文书
《三亚落日》教学反思
2014/04/26 职场文书
我的梦想演讲稿500字
2014/08/21 职场文书
搞笑Gif:这么白这么长的腿像极了一楼的女朋友
2022/03/21 杂记