Jquery-ui 保存可拖动项的位置

Jquery-ui Save position of draggable item

我想将可拖动项目的 x 和 y 位置的变量保持在停止状态。 感谢一些 fiddle 和主题,我这样做了:

$("#image").draggable({
        helper: 'clone',
    stop:function(event,ui) {
        var wrapper = $("#wrapper").offset();
        var borderLeft = parseInt($("#wrapper").css("border-left-width"),10);
        var borderTop = parseInt($("#wrapper").css("border-top-width"),10);
        var pos = ui.helper.offset();
        $("#source_x").val(pos.left - wrapper.left - borderLeft);
        $("#source_y").val(pos.top - wrapper.top - borderTop);
        alert($("#source_x").val() + "," + $("#source_y").val());
    }
});

我只想在每次移动项目时保存位置并在其他 javascript 函数中使用它。

这是 fiddle.js :

http://jsfiddle.net/oe0fg84b/

尝试使用以下代码。如果我猜对了,这可能就是解决方案。

var moved_times_index = 0;
var postionssaved_object = {};
$("#image").draggable({
        helper: 'clone',
    stop:function(event,ui) {
        var wrapper = $("#wrapper").offset();
        var borderLeft = parseInt($("#wrapper").css("border-left-width"),10);
        var borderTop = parseInt($("#wrapper").css("border-top-width"),10);
        var pos = ui.helper.offset();
        $("#source_x").val(pos.left - wrapper.left - borderLeft);
        $("#source_y").val(pos.top - wrapper.top - borderTop);
        alert($("#source_x").val() + "," + $("#source_y").val());
        moved_times_index++;
        postionssaved_object[moved_times_index] =   [$("#source_x").val(), $("#source_y").val()];
    }
});

如@John 所述,您似乎已经将可拖动图像的 x 和 y 坐标分别存储在元素 #source_x 和 #source_y 中。

您应该可以在另一个函数中访问它们,如下所示:

var x =$("#source_x").val(); 
var y = $("#source_y").val();

只是观察,您的助手 属性 克隆似乎导致图像在被拖动后重置其位置。我怀疑这会覆盖您的坐标值,每次都重置为 0,0。尝试:

$("#image").draggable({
stop:function(event,ui) {
    var wrapper = $("#wrapper").offset();
    var borderLeft = parseInt($("#wrapper").css("border-left-width"),10);
    var borderTop = parseInt($("#wrapper").css("border-top-width"),10);
    var pos = ui.helper.offset();
    $("#source_x").val(pos.left - wrapper.left - borderLeft);
    $("#source_y").val(pos.top - wrapper.top - borderTop);
    alert($("#source_x").val() + "," + $("#source_y").val());
    }
});

我修改了您的示例,以便稍后在单击按钮时获取坐标:http://jsfiddle.net/Jason_Graham/oe0fg84b/2/