这次记录就不贴代码了,只是记录一下原理和思路,因为代码封装的太严格,所以不好拿出来。
lz的页面是左右各一个分隔条实现拖拽的,左边是框架自带一个功能没问题,右边是lz模仿做的,结果样子是做出来了,就是左右拖拽的方向反了,向左拖应该是增大,它却缩小,向右应该是缩小,却是增大。
这个问题停了好几天,终于静下心来解决了。废话不说了,我直接说思路,大家有问题的话也可以试一下;
概述:实现拖拽工作流程配置,可以鼠标左右移动元素,来控制div的宽度;
基本原理:就是根据鼠标的移动来移动被拖拽的元素。鼠标的移动也就是x、y坐标的变化;元素的移动就是style.position的 top和left的改变。当然,并不是任何时候移动鼠标都要造成元素的移动,而应该判断鼠标左键的状态是否为按下状态,是否是在可拖拽的元素上按下的。
拖拽状态 = 0鼠标在元素上按下的时候{
拖拽状态 = 1
记录下鼠标的x和y坐标
记录下元素的x和y坐标
}
鼠标在元素上移动的时候{
如果拖拽状态是0就什么也不做。
如果拖拽状态是1,那么
元素y = 现在鼠标y - 原来鼠标y + 原来元素y
元素x = 现在鼠标x - 原来鼠标x + 原来元素x
}
鼠标在任何时候放开的时候{
拖拽状态 = 0
}
lz遇到的问题是:
向左拖拽 结果会缩小 应该是增大。 1095-1119 +240 = 216 p.x < start.x
向右拖动 结果会增大 应该是缩小 1145-1119 +240 = 266 p.x > start.x
经过上述推理,最后的解决方法是:
//p.x :拖拽后的x坐标;
//start.x : 未拖拽时的x坐标,也就是默认的;
//当x大于默认的x坐标时,是向左,应该是增大宽度
if(p.x < start.x){
绝对值+宽度
}else if(p.x > start.x){//当x小于默认的x坐标时,是向右,应该是缩小宽度
//取负数 + 240
}
最后呢完美解决,分隔条的代码呢网上搜一下好多,具体大家可以挑一个来使用。如果遇到问题呢还是先好好分析一下这个拖拽的原理。如果有问题还请大家留言讨论。