Axure:实现列表上下拖动的方法野史趣闻
2018-09-15 22:00:24
如何用Axure实现列表拖动排序?这篇文章《Axure教程:列表拖动排序的实现方式 》 提出用中继器可以实现,但是明确指出只能向上拖动。本文有个方法,不仅可以向上拖动,还可以向下拖动。

手动实现效果如下:

步骤如下,大神轻拍。
拖动开始时:
- 记录被拖动条目当前的y坐标值;
- 设置文字便于观察(下同)。
拖动时:
- 设置拖动边界;
- 将当前拖动的条目置于顶层;
- 记录拖动时y坐标值;
- 计算拖动距离。

拖动结束后:
- 根据被拖动条目的运动方向以及其他条目与被拖动条目的相对位置进行判断,确定受影响条目,并计算被影响条目应该移动的距离(相对距离,y轴方向移动距离为一个条目高度)和方向。
- 修正拖动距离,以条目高度50为例,拖动距离求余,取50余数舍去。计算公式:[[dragy_instance-dragy_instance%50]],dragy_instance为实际拖动距离正负值皆可使用此公式计算。
- 修正拖动后位置,移动距离[[dragy_instance_modify-dragy_instance]]。



本文由 @y13110 原创发布于人人都是产品经理。未经许可,禁止转载
题图来自 Unsplash ,基于 CC0 协议
本文作者:人人都是产品经理(今日头条)