对于我的应用程序,在一个元素被拖动并捕捉到可放置区域后,我需要继续允许该拖动的项目仅垂直移动。我已经完成了这项工作,但我还需要将该项目仅拖动并捕捉到像素增量。如何才能做到这一点?
例如,我有一个时间线,我需要元素以 15 分钟为增量对齐。我需要知道这是否可以通过可拖动功能实现,还是我需要想出一些混合滑块?如果可能的话,我宁愿不使用一些混合方法。
代码片段:
$(".activity_link").draggable({
"snap": ".trek_slider",
"snapMode": "inner",
// "snapTolerance" : 30,
"revert": function (event, ui) {
// on older version of jQuery use "draggable"
// $(this).data("draggable")
// on 2.x versions of jQuery use "ui-draggable"
// $(this).data("ui-draggable")
$(this).data("uiDraggable").originalPosition = {
top: 0,
left: 0
};
$(this).draggable("option", "axis", false);
// return boolean
return !event;
// that evaluate like this:
// return event !== false ? false : true;
}
});
$(".trek_slider").droppable({
"tolerance": "touch",
"over": function (event,
ui) {
var left_position = parseInt($(ui.draggable).css("left"));
$(ui.draggable).find(".activity_caret").show();
$(ui.draggable).draggable("option", "axis", "y");
}
});