实现拖拽案例浏览器
效果以下图所示:spa
代码以下图所示:3d
代码思路说明:blog
第23行代码:在div元素中触发onmousedown事件,实现鼠标在div按下,不提起功能 【区别于onclick,onclick:按下、提起事件,属于两个动做(即:onmousedown+onmouseup)】事件
第20-21行代码:声明变量,用于计算鼠标按下位置到div位置长度距离 (详细见下图解释分析)内存
第24-25行代码:设置鼠标按下位置到div位置长度距离(即:鼠标位置-div左边距到浏览器的长度距离) (详细见下图解释分析)变量
第27行代码:鼠标移动事件 当div按下触发此事件,让div整屏可移动,这就是“document.onmousemove”的做用cli
第28-29行代码:让div移动,即改变div的左边距/上边距到浏览器的距离长度(记得加‘px’单位) 而div左边距到浏览器的距离长度=鼠标位置-鼠标按下位置到div位置长度距离 (详细见下图解释分析)sed
第32行代码:鼠标提起事件bug
第33-34行代码:关闭移动事件并关闭不须要的提起事件以节省内存空间
第37行代码:return false 用于解决ff旧版本(空值div拖拽bug)的兼容问题,而设置的阻止默认事件
详细解释距离的问题,以下图:(讲解20-2一、24-2五、28-29行的代码)
以上简单拖拽案例,足以知足需求了,可是,以上所编写的代码还有一点bug,那就是:当用户把div拖拽至浏览器外并松手,div就会消失不见,怎么找都找不回。
因此,修改以上bug,实现:div只能在浏览器范围内实现拖拽现象(防止拖出页面)
修改后的代码以下图:
效果以下图所示: