jQuery偏移位置根据包含位置

时间:2014-08-22 10:04:26

标签: javascript jquery

<script>
$(document).ready(function(e) {
    $(function(){
        $( "#draggable" ).draggable({
            containment: "#box",
            drag: function(){
                var offset = $(this).offset();
                var xPos = offset.left;
                var yPos = offset.top;

                $('#posX').val('x: ' + xPos);
                $('#posY').val('y: ' + yPos);
            }
        });
    });
});
</script>

<style>
body{margin:0;}
#draggable{width:100px; height:100px; background:red;}
#box{width:500px; height:500px; border:solid 1px #000; margin:100px;}
</style>
<div id="box">
    <div id="draggable"></div>
</div>
<input id="posX" type="text" />
<input id="posY" type="text" />

我有一个div使用jQuery draggable并检测位置。

我的问题是如何根据收容$('#box')获取偏移位置,而不是根据文件?

1 个答案:

答案 0 :(得分:2)

由于可拖动元素附加到正文中,因此在拖动时它根本不在#box元素内部,因此您必须减去包含元素的位置,并且在您的情况下边界也是如此,以获得正确的价值

$(function(){
    var box    = $('#box').offset(),
        border = parseInt($('#box').css('border-width').replace(/\D/g,''), 10);

    $( "#draggable" ).draggable({
        containment: "#box",
        drag: function(){
            var offset = $(this).offset();
            var xPos = offset.left - box.left - border;
            var yPos = offset.top - box.top - border;

            $('#posX').val('x: ' + xPos);
            $('#posY').val('y: ' + yPos);
        }
    });
});

FIDDLE