Javascript-форум (https://javascript.ru/forum/)
-   Элементы интерфейса (https://javascript.ru/forum/dom-window/)
-   -   Сохранение порядка расположения блоков (https://javascript.ru/forum/dom-window/42798-sokhranenie-poryadka-raspolozheniya-blokov.html)

potomuchto 10.11.2013 14:44

Сохранение порядка расположения блоков
 
Здравствуйте.

Есть определенной количество блоков, которые сами по себе являются строками на всю ширину блока, в который они вложены.

К ним прикручена jquery функция (метод??) sortable:
// Конвертируем UL со всеми пунктами в сортированный список:
	$("ul.sort").sortable({
		handle : '.title-infos-left',
		axis:'y',
		containment: 'document',
		opacity: 0.6
	});


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

skrudjmakdak 10.11.2013 15:20

вот здесь рассказывают про куки, как их сохр
http://ruseller.com/lessons.php?rub=28&id=593

после сортировки, сохраняйте параметры в куки, а при загрузки страницы, например body onload доставайте значения и сортируйте по этим значениям..

skrudjmakdak 10.11.2013 15:22

вот еще материал про куки
http://learn.javascript.ru/cookie

рони 10.11.2013 16:45

jQuery UI Sortable сохранение порядка сортировки при перезагрузке
 
:write:
<!DOCTYPE html>

<html lang="en">
<head>
  <meta charset="utf-8">

  <title>jQuery UI Sortable - Default functionality</title>
  <link rel="stylesheet" href="http://code.jquery.com/ui/1.10.3/themes/smoothness/jquery-ui.css">
  <script src="http://code.jquery.com/jquery-1.9.1.js">
</script>
  <script src="http://code.jquery.com/ui/1.10.3/jquery-ui.js">
</script>
  <link rel="stylesheet" href="/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; }

  </style>
  <script>

  $(function () {
    var rang = JSON.parse(localStorage.getItem('rang')) || [],
    li = $("#sortable li"),
    arr = [];
    for (var i = 0; i < rang.length; i++) {
    arr.push(li[rang[i] - 1])
    }
    rang.length && $(arr)
    .appendTo($("#sortable")) && $(".out")
    .text(rang);;
$("#sortable")
    .sortable({
        stop: function (event, ui) {
            rang = [];
            $("#sortable li")
                .each(function (indx, element) {
                    rang.push(1 + li.index(element) + " ");
                });
            $(".out")
                .text(rang);
            localStorage.setItem('rang', JSON.stringify(rang));
        }
    });
$("#sortable")
    .disableSelection();
  });
  </script>
</head>

<body>
  <div class="out">
    1 ,2 ,3 ,4 ,5 ,6 ,7
  </div>

  <ul id="sortable">
    <li class="ui-state-default">Item 1</li>

    <li class="ui-state-default">Item 2</li>

    <li class="ui-state-default">Item 3</li>

    <li class="ui-state-default">Item 4</li>

    <li class="ui-state-default">Item 5</li>

    <li class="ui-state-default">Item 6</li>

    <li class="ui-state-default">Item 7</li>
  </ul>
</body>
</html>

potomuchto 12.11.2013 00:04

Спасибо огромное!


Часовой пояс GMT +3, время: 10:54.