jquery - 拖放在缩放容器时无法正常工作

标签 jquery html jquery-ui drag-and-drop

当我将容器缩放到 0.5 时,DND 无法正常运行。 请任何人帮我解决这个问题。

HTML:

<div id="container">
<div id="dragContainer">
<div class="draggable">drag1</div>
<div class="draggable">drag2</div>
</div>
<div id="dropContainer">
<div class="droppable">drop1</div>
<div class="droppable">drop2</div>
</div>
</div>

JS:

$(".draggable").draggable({
    revert: 'invalid'
})
$(".droppable").droppable()

我已经创建了该问题的 fiddle 链接:https://jsfiddle.net/7eqnhsp3/

最佳答案

我创建了在任何缩放情况下都可以运行的演示

    <html>
    <head>
    <style>
    #container{
      width:500px;
      height:500px;
      position:absolute;
      top:0px;
      left:0px;
      border:1px solid;
      -ms-transform: scale(0.8,0.8); /* IE 9 */
      -webkit-transform: scale(0.8,0.8); /* Safari */
       transform: scale(1,1);

    }
    #dragContainer,#dropContainer{
     width:200px;
      height:500px;
      position:relative;
      margin-top:0px;
      margin-left:0px;
      border:1px solid gray;
      float:left;
    }
    .draggable{
      width:50px;
      height:30px;
      background:#990000;
      border:1px solid;
      z-index:1;
    }
    .droppable{
      width:50px;
      height:30px;
      background:#aa0000;
      border:1px solid;
    }
    </style>
    <script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/3.0.0-beta1/jquery.js"></script>
    <script src="https://cdnjs.cloudflare.com/ajax/libs/jqueryui/1.11.4/jquery-ui.js"></script>
    <script>
    var zoomScale=1;
        $(document).ready(function(){

                $(".draggable").draggable({
                revert: 'invalid'
                })
                $(".draggable").draggable({
                    //start: startFix,
                    drag: dragFix
                });
                $(".droppable").droppable()

        })


            function dragFix(event, ui) {
                var changeLeft = ui.position.left - ui.originalPosition.left; // find change in left
                var newLeft = ui.originalPosition.left + changeLeft / zoomScale; // adjust new left by our zoomScale

                var changeTop = ui.position.top - ui.originalPosition.top; // find change in top
                var newTop = ui.originalPosition.top + changeTop / zoomScale; // adjust new top by our zoomScale

                ui.position.left = newLeft;
                ui.position.top = newTop;

            }
    </script>
    </head>
    <body>


    <div id="container">
    <div id="dragContainer">
    <div class="draggable">drag1</div>
    <div class="draggable">drag2</div>
    </div>
    <div id="dropContainer">
    <div class="droppable">drop1</div>
    <div class="droppable">drop2</div>
    </div>
    </div>
    </body>
    </html>

关于jquery - 拖放在缩放容器时无法正常工作,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/36589332/

相关文章:

php - 如何在不刷新的情况下在页面上获得实时信息?

javascript - 切换时多个 slider 崩溃

jQuery - 当屏幕小于1350px时按类删除div

html - 如果未在其上方单击,则 Bootstrap 弹出窗口隐藏

javascript - Google 图表进入 JQuery Tab 绘制问题

jQuery getJSON 调用未返回所需的参数?

javascript - 使用 javascript 或 jquery 编辑浏览器的查询字符串

javascript - HTML onclick 未运行函数

javascript - JQuery 与 Draggable 一起生活不工作动态 HTML

jquery - jquery mobile 中刷新单选按钮的问题