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 相关文章推荐
从JavaScript的函数重名看其初始化方式
Mar 08 Javascript
用javascript获取当页面上鼠标光标位置和触发事件的对象的代码
Dec 09 Javascript
Jquery替换已存在于element上的event的方法
Mar 09 Javascript
Javascript this 的一些学习总结
Aug 31 Javascript
jquery中trigger()无法触发hover事件的解决方法
May 07 Javascript
jQuery 常用代码集锦(必看篇)
May 16 Javascript
玩转NODE.JS(四)-搭建简单的聊天室的代码
Nov 11 Javascript
node通过npm写一个cli命令行工具
Oct 12 Javascript
angularJS的radio实现单项二选一的使用方法
Feb 28 Javascript
官方推荐react-navigation的具体使用详解
May 08 Javascript
JavaScript继承的特性与实践应用深入详解
Dec 30 Javascript
微信小程序实现录音Record功能
May 09 Javascript
如何构建一个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
php中对2个数组相加的函数
2011/06/24 PHP
php不用正则验证真假身份证
2013/11/06 PHP
PHP中创建图像并绘制文字的例子
2014/11/19 PHP
php常用hash加密函数
2014/11/22 PHP
CodeIgniter与PHP5.6的兼容问题
2015/07/16 PHP
详解PHP使用日期时间处理器Carbon人性化显示时间
2017/08/10 PHP
PHP5.6新增加的可变函数参数用法分析
2017/08/25 PHP
获取Javscript执行函数名称的方法
2006/12/22 Javascript
基于datagrid框架的查询
2013/04/08 Javascript
实例说明为什么不要行内使用javascript
2014/04/18 Javascript
JQuery获取表格数据示例代码
2014/05/26 Javascript
JavaScript分页功能的实现方法
2015/04/25 Javascript
灵活使用数组制作图片切换js实现
2016/07/28 Javascript
jQuery实现简单的抽奖游戏
2017/05/05 jQuery
vue实现百度搜索下拉提示功能实例
2017/06/14 Javascript
Node.js 中如何收集和解析命令行参数
2021/01/08 Javascript
Python安装Imaging报错:The _imaging C module is not installed问题解决方法
2014/08/22 Python
浅谈Python类的__getitem__和__setitem__特殊方法
2016/12/25 Python
利用matplotlib+numpy绘制多种绘图的方法实例
2017/05/03 Python
python实现视频分帧效果
2019/05/31 Python
pygame实现打字游戏
2021/02/19 Python
Python实现i人事自动打卡的示例代码
2020/01/09 Python
纯css3实现思维导图样式示例
2018/11/01 HTML / CSS
canvas学习笔记之绘制简单路径
2019/01/28 HTML / CSS
墨西哥网上超市:Superama
2018/07/10 全球购物
Juicy Couture Beauty官方网站:香水和化妆品
2019/03/12 全球购物
英国设计师泳装、沙滩装和比基尼在线精品店:Beach Cafe
2019/08/28 全球购物
泰国第一在线超市:Tops
2021/02/13 全球购物
创新比赛获奖感言
2014/02/13 职场文书
《两个铁球同时着地》教学反思
2014/02/13 职场文书
大学活动总结模板
2014/07/10 职场文书
社保委托书怎么写
2014/08/02 职场文书
个人年终总结开头
2015/03/06 职场文书
工作态度恶劣检讨书
2015/05/06 职场文书
实习报告范文
2019/07/30 职场文书
nginx location优先级的深入讲解
2021/03/31 Servers