MooTools - Сортируемые

Sortables - это продвинутая функция в веб-разработке, которая действительно открывает возможности для дизайна вашего пользовательского интерфейса. Он также включает в себя отличную функцию под названием «сериализация», которая управляет списком идентификаторов элементов и полезна для сценариев на стороне сервера.

Создание нового сортируемого объекта

Сначала мы отправляем список элементов в переменную. Если вам нужен массив списка элементов, присвойте всю коллекцию переменной. И, наконец, передайте эту переменную сортируемому конструктору. Взгляните на следующий синтаксис, чтобы создать сортируемый объект.

Синтаксис

var sortableListsArray = $$('#listA, #listB');
var sortableLists = new Sortables(sortableListsArray);

Ниже приведен HTML-код синтаксиса.

Синтаксис

<ul id = "listA">
   <li>Item A1</li>
   <li>Item A2</li>
   <li>Item A3</li>
   <li>Item A4</li>
</ul>

<ul id = "listB">
   <li>Item B1</li>
   <li>Item B2</li
   <li>Item B3</li>
   <li>Item B4</li>
</ul>

Вариант сортировки

Sortable предоставляет различные параметры для настройки сортируемого объекта. Обсудим варианты.

Сдерживать

Эта опция определяет, могут ли элементы списка перемещаться между ul в сортируемом объекте. Например, если у вас есть две ul в сортируемом объекте, вы можете "constrain"элементы списка их родительской ul путем установки"constrain: true". Взгляните на следующий синтаксис для установки ограничения.

Syntax

var sortableLists = new Sortables(sortableListsArray, {
   constrain: true //false is default
});

Клонировать

Эта опция помогает вам создать клонированный элемент под курсором. Это помогает в сортировке элементов списка. Взгляните на следующий синтаксис для clone.

Syntax

var sortableLists = new Sortables(sortableListsArray, {
   clone: true //false is default
});

Справиться

Ручка - это опция, которая принимает элемент в качестве ручки перетаскивания. Это полезно, когда вы хотите, чтобы элементы вашего списка можно было выбирать или какие-либо действия в вашем списке. Если вы не укажете какую-либо переменную, по умолчанию она будет считаться ложной. Взгляните на следующий синтаксис использования дескриптора.

Syntax

var handleElements = $$('.handlesClass');
var sortableLists = new Sortables(sortableListsArray, {
   handle: handleElements //false is default
});

Непрозрачность

Этот параметр позволяет настроить элемент сортировки. Если вы используете клон, непрозрачность влияет на сортируемый элемент.

Syntax

var sortableLists = new Sortables(sortableListsArray, {
   opacity: 1 //default is 1
});

Вернуть

Этот параметр принимает либо «false», либо любой вариант Fx. Если вы установите опцию Fx в revert, это создаст эффект для сортированного элемента, чтобы он встал на место. Взгляните на следующий синтаксис для возврата.

Syntax

var sortableLists = new Sortables(sortableListsArray, {
   revert: false //this is the default
});

//you can also set Fx options
var sortableLists = new Sortables(sortableListsArray, {
   revert: {
      duration: 50
   }
});

Щелчок

Этот параметр позволяет вам увидеть, на сколько пикселей перетащит мышь, прежде чем элемент начнет следовать.

Syntax

var sortableLists = new Sortables(sortableListsArray, {
   snap: 10 //user will have to drag 10 px to start the list sorting
});

Сортируемые события

Sortable предоставляет следующие удобные и понятные события.

  • onStart - выполняется, когда начинается перетаскивание (после того, как привязка срабатывает)

  • onSort - выполняется при изменении порядка элементов

  • onComplete - выполняется, когда вы бросаете элемент на место

Сортируемые методы

Следующие сортируемые методы по сути являются функциями, принадлежащими классам:

отсоединить ()

С помощью detach () вы можете «отсоединить» все текущие дескрипторы, сделав весь объект списка недоступным для сортировки. Это полезно для отключения сортировки.

прикреплять()

Этот метод «прикрепляет» дескрипторы к элементам сортировки, работает, чтобы включить сортировку после detach ().

addItems ()

Это позволяет добавлять новые элементы в сортируемый список. Допустим, у вас есть сортируемый список, в который пользователь может добавить новый элемент. После добавления этого нового элемента вам нужно будет включить сортировку для этого нового элемента.

removeItems ()

Этот метод позволяет удалить возможность сортировки элемента в сортируемом списке. Это полезно, когда вы хотите заблокировать определенный элемент в определенном списке и не позволять ему сортировать с другими.

addLists ()

Вместо того, чтобы просто добавлять новый элемент в существующий список, вы можете добавить целый новый список к сортируемому объекту. Этот метод позволяет добавлять несколько списков, что значительно упрощает добавление дополнительных объектов сортировки.

removeLists ()

Удалим списки из сортируемого объекта. Это полезно, когда вы хотите заблокировать определенный список на месте. Вы можете удалить список, оставив другие списки по-прежнему в сортируемом объекте, но заблокировав содержимое удаленного списка.

сериализовать ()

Вся эта сортировка великолепна, но что, если вы хотите что-то сделать с данными? .serialize (); вернет список идентификаторов элементов, а также их порядок в списке. Вы можете выбрать, из какого списка получать данные из объекта по номеру индекса.

пример

В следующем примере создается массив элементов div с нумерацией. Позже измените их порядок, щелкнув, перетащив и отпустив с помощью указателя мыши. Взгляните на следующий код.

<!DOCTYPE html>
<html>
   
   <head>
      <style>
         #test {
            position: inherit;
         }
         ul#sortables {
            width: 300px;
            margin: 0;
            padding: 0;
         }
         li.sortme {
            padding: 4px 8px;
            color: #fff;
            cursor: pointer;
            list-style: none;
            width: 300px;
            background-color: #222;
            border: 1px solid;
         }
         ul#sortables li {
            margin: 10px 0;
         }
      </style>
      
      <script type = "text/javascript" src = "MooTools-Core-1.6.0.js"></script>
      <script type = "text/javascript" src = "MooTools-More-1.6.0.js"></script>
      
      <script type = "text/javascript">
         window.addEvent('domready', function() {
            new Sortables($('test'), {
               initialize: function(){
                  var step = 0;
                  
                  this.elements.each(function(element, i) {
                     var color = [step, 82, 87].hsbToRgb();
                     element.setStyle('background-color', color);
                     step = step + 35;
                     element.setStyle('height', $random(40, 100));
                  });
               }
            });
         });
      </script>
   </head>
   
   <body>
      <ul id = "test">
         <li class = "sortme">0</li>
         <li class = "sortme">1</li>
         <li class = "sortme">2</li>
         <li class = "sortme">3</li>
         <li class = "sortme">4</li>
         <li class = "sortme">5</li>
         <li class = "sortme">6</li>
         <li class = "sortme">7</li>
         <li class = "sortme">8</li>
         <li class = "sortme">9</li>
         <li class = "sortme">10</li>
      </ul>
   </body>
   
</html>

Вы получите следующий вывод -

Вывод