Сортируемый JQuery UI не сортируется при перетаскивании на половину высоты

Решено: containment: $("#sortable").parent().parent();

ОБНОВЛЕНИЕ: Вот видео объяснение этого.

Я действительно не знаю, как задать этот вопрос, я не знаю, как это работает, и поэтому мне нужна небольшая помощь здесь:

Когда я перетаскиваю второй элемент из списка и, скажем, высота элемента составляет 50px, когда я щелкаю и перетаскиваю от 0-25px сверху вниз на элементе, чтобы перетащить его на первое место, первый перемещается вниз, но если я нажимаю и перетаскиваю из 26-50px сверху вниз на предмете и попытайтесь переместиться на первое место, первый предмет не опускается.

Теперь я предполагаю, что он работает с позицией мыши и половиной высоты элемента, как если бы позиция мыши была выше, не перетаскивая элемент менее чем на 50% высоты элемента, он перемещается вниз, в противном случае он не перемещается.

Как я могу изменить это так, чтобы он блокировал перетаскиваемый элемент на мышь на 50% верхней позиции или где когда-либо щелкали и перемещали по какому-то элементу для перемещения вниз?

<!doctype html>
<html lang="en">
<head>
  <meta charset="utf-8">
  <meta name="viewport" content="width=device-width, initial-scale=1">
  <title>jQuery UI Sortable - Default functionality</title>
  <link rel="stylesheet" href="https://code.jquery.com/ui/1.12.1/themes/base/jquery-ui.css">
  <link rel="stylesheet" href="https://jqueryui.com/resources/demos/style.css">
  <style>
  #sortable { list-style-type: none; margin: 0; padding: 0; width: 60%; }
  #sortable li { margin: 0 3px 3px 3px; padding: 0.4em; padding-left: 1.5em; font-size: 1.4em; height: 18px; }
  #sortable li span { position: absolute; margin-left: -1.3em; }
 div{
    width: 60%;
    height: auto;
    padding: 20px 0;
    background: red;
 }
 </style>
  <script src="https://code.jquery.com/jquery-1.12.4.js"></script>
  <script src="https://code.jquery.com/ui/1.12.1/jquery-ui.js"></script>
  <script>
  $( function() {
    $( "#sortable" ).sortable({
     containment: $("#sortable").parent().parent(), 
     update: function(){
         alert('Dropped!'); 
        }
    });
    $( "#sortable" ).disableSelection();
  } );
  </script>
</head>
<body>
<div>
<ul id="sortable">
  <li class="ui-state-default"><span class="ui-icon ui-icon-arrowthick-2-n-s"></span>Item 1</li>
  <li class="ui-state-default"><span class="ui-icon ui-icon-arrowthick-2-n-s"></span>Item 2</li>
  <li class="ui-state-default"><span class="ui-icon ui-icon-arrowthick-2-n-s"></span>Item 3</li>
  <li class="ui-state-default"><span class="ui-icon ui-icon-arrowthick-2-n-s"></span>Item 4</li>
  <li class="ui-state-default"><span class="ui-icon ui-icon-arrowthick-2-n-s"></span>Item 5</li>
  <li class="ui-state-default"><span class="ui-icon ui-icon-arrowthick-2-n-s"></span>Item 6</li>
  <li class="ui-state-default"><span class="ui-icon ui-icon-arrowthick-2-n-s"></span>Item 7</li>
</ul>
 
 
</body>
</html>

1 ответ

Когда вы перетаскиваете из маленькой стрелки "вверх-вниз", она работает каждый раз. Попробуйте отредактировать настройки цели или родителей.

Другие вопросы по тегам