前言
本文主要给大家介绍了一种利用jQuery实现的简单拖曳效果,分享出来供大家参考学习,下面话不多说了,来一起看看详细的介绍吧。
提出问题
如何实现将一个盒子里的元素拉到另外一个盒子里?
实现思路
- 此操作包含的事件有 mousedown mousemove mouseup,对这三个事件进行监听并进行相应的操作。
- 操作设计的节点有:原节点,临时节点,新节点
- 节点的移动涉及事件e的坐标
- 操作元素使用JQUERY
代码实现
相应的注释在文中已有体现,请认真观看,你可以理解的。
- 先定义一个对象 drag,包含拖曳需要用到的参数
- 定义初始化 init 函数,监听各种鼠标事件
- mousedown 事件:克隆一个临时节点。记录鼠标点击位置与节点的位置的X,Y差值,设置克隆副本的样式并在原容器中添加这个副本
- mousemove 事件:判断鼠标的相对位移,设置副本绝对位置的XY,并对鼠标移出浏览器的情况进行处理;对三个UL进行遍历,在不是原容器的情况下,判断鼠标位置是否处于其他容器的范围内,如果是,修改鼠标当前容器的样式。
- mouseup 时间:移除临时节点。对三个UL进行遍历,在不是原容器的情况下,判断鼠标位置是否处于其他容器的范围内,如果是,在该容器下加入新节点,原容器删除原节点。