【问题标题】:Get position of dragable object, relative to a div获取可拖动对象相对于 div 的位置
【发布时间】:2015-09-26 11:51:39
【问题描述】:

这里是jsFiddle,我有一个足球场,用户应该将 10 名球员分成两支五人球队。我想知道他是把球员拖到左边还是晚上(假设场地的中心线是边界)。

这里是js代码:

$(".dragNdrop").draggable({
  drag: function(){
    var offset = $(this).offset();
    var xPos = offset.left;
    var yPos = offset.top;
      console.log('x: ' + xPos);
      console.log($('#footballField').width());
    }
});

我也尝试过 position()offset(),但似乎找不到合适的公式。

那么,如何判断玩家是在div的左侧还是右侧呢?

相关问题:How to get the position of a draggable object

【问题讨论】:

    标签: javascript jquery html css drag


    【解决方案1】:

    如果$('#footballField').width()是字段的宽度,可以检查dragNdrop元素的xPos是小还是大比 footballField 左边 + 他的宽度除以 2:

    $(".dragNdrop").draggable({
        drag: function(){
            var offset = $(this).offset();
            var xPos = offset.left;
            var yPos = offset.top;
            console.log('x: ' + xPos);
            //console.log('y: ' + yPos);
            console.log('offset: ' + $('#footballField').offset().left);
            var fieldLeft = $('#footballField').offset().left;
            console.log($('#footballField').width());
            if(xPos < fieldLeft + $('#footballField').width()/2){
                 console.log('I am at left');
            }else{
                console.log('I am at right');
            }
    
        }
    });
    

    【讨论】:

    • 哈哈哈很高兴我帮助了你;-)
    猜你喜欢
    • 2011-06-21
    • 2012-08-25
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    相关资源
    最近更新 更多