jQuery根据包含位置偏移位置

jQuery offset position according containment position

本文关键字:位置 包含 jQuery      更新时间:2023-09-26
<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可拖动和检测的位置。

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

由于可拖拽元素是附加在body上的,因此在拖拽时它根本不在#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);
        }
    });
});

小提琴