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 相关文章推荐
js将当前时间格式转换成时间搓(自写)
Sep 26 Javascript
jquery实现Li滚动时滚动条自动添加样式的方法
Aug 10 Javascript
jQuery中attr()与prop()函数用法实例详解(附用法区别)
Dec 29 Javascript
javascript先序遍历DOM树的方法
Feb 27 Javascript
Node.js连接postgreSQL并进行数据操作
Dec 18 Javascript
$.browser.msie 为空或不是对象问题的多种解决方法
Mar 19 Javascript
vue mixins组件复用的几种方式(小结)
Sep 06 Javascript
利用HBuilder打包前端开发webapp为apk的方法
Nov 13 Javascript
webpack引入eslint配置详解
Jan 22 Javascript
百度地图去掉marker覆盖物或者去掉maker的label文字方法
Jan 26 Javascript
Angular路由ui-router配置详解
Aug 01 Javascript
简述vue状态管理模式之vuex
Aug 29 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程序员的技术瓶颈分析
2011/07/17 PHP
PHP在线生成二维码(google api)的实现代码详解
2013/06/04 PHP
onpropertypchange
2006/07/01 Javascript
用js得到网页中所有的div的id
2020/10/19 Javascript
JavaScript 原型链学习总结
2010/10/29 Javascript
Mac地址验证的javascript代码
2013/11/09 Javascript
解析JavaScript中的不可见数据类型
2013/12/02 Javascript
Nodejs实现的一个简单udp广播服务器、客户端
2014/09/25 NodeJs
浅谈json取值(对象和数组)
2016/06/24 Javascript
js 获取站点应用名的简单实例
2016/08/18 Javascript
xmlplus组件设计系列之下拉刷新(PullRefresh)(6)
2017/05/03 Javascript
Javascript Promise用法详解
2018/05/10 Javascript
浅谈webpack+react多页面开发终极架构
2018/11/11 Javascript
js微信分享接口调用详解
2019/07/23 Javascript
python不带重复的全排列代码
2013/08/13 Python
Python获取DLL和EXE文件版本号的方法
2015/03/10 Python
关于Python的一些学习总结
2018/05/25 Python
python 将md5转为16字节的方法
2018/05/29 Python
Python for循环生成列表的实例
2018/06/15 Python
解决tensorflow测试模型时NotFoundError错误的问题
2018/07/27 Python
python验证身份证信息实例代码
2019/05/06 Python
pytorch使用 to 进行类型转换方式
2020/01/08 Python
python实现用户名密码校验
2020/03/18 Python
Python3基于print打印带颜色字符串
2020/07/06 Python
python 判断一组数据是否符合正态分布
2020/09/23 Python
HTML5 HTMLCollection和NodeList的区别详解
2020/04/29 HTML / CSS
欧洲第一中国智能手机和平板电脑网上商店:CECT-SHOP
2018/01/08 全球购物
"序列点" 是什么
2016/07/29 面试题
2014年科普工作总结
2014/12/06 职场文书
保证金退回承诺函格式
2015/01/21 职场文书
主持人开幕词
2015/01/29 职场文书
在职证明书模板
2015/06/15 职场文书
如何书写民事调解协议书?
2019/06/25 职场文书
MySql学习笔记之事务隔离级别详解
2021/05/12 MySQL
HTML5 语义化标签(移动端必备)
2021/08/23 HTML / CSS
Python Pygame实战之塔防游戏的实现
2022/03/17 Python