.draggable + .droppable + .sortable
Всем доброго времени суток!
Нужно организовать такую штуку: Что бы можно было товары сортировать по группам, как вы уже поняли при помощи drag and drop Суть заключается в том, что бы пользователь мог перемещать элементы не только по группам(div'ам), но и сортировать эти элементы внутри них... Вот код, но он не хочет работать, вернее он перемещает в дивы, но не позволяет сортировать их, в чем ошибка?
var groupPrice = {
0:'#block2',
1:'#block3'
}
$(function() {
$('.textBlock').draggable({
helper:'clone',
cursor: 'move',
stop: function(){
$(this).css("background-color", "red");
}
});
for (var key in groupPrice) {
$(groupPrice[key]).droppable({
hoverClass: 'dropHere'
,drop: function(event, ui) {
$(this).append($('<div class="textBlock">' + ui.draggable.html() + '</div>'));
$(this).sortable({ opacity: 0.8, cursor: 'move', update: function() {alert("Изменено");}});
}
});
}
});
HTML:
<div class="wrapper">
Перетащите
<div id="block1">
<div class="textBlock">Товар 1</div>
<div class="textBlock">Товар 2</div>
<div class="textBlock">Товар 3</div>
</div>
<div id="block2"></div>
<div id="block3"></div>
</div>
Видел тему: http://javascript.ru/forum/jquery/16...mozhno-li.html , так и не понял до конца, что у меня не правильно? |
Неужели никто не знает?
|
нишиша непонял, из того что вы хотите.
dragable можно напрямую к sortable приконектить, без dropable а несколько sortable можно обьединить, и дать возможность перетаскивать из одного в другой В примере перестановка товаров между группами выполнена силами одного sortable, а для добавления новых товаров я применил dragable. dropable нам не понадобился.
<!doctype html>
<html lang="en">
<head>
<meta charset="utf-8" />
<title>jQuery UI Draggable + Sortable</title>
<link rel="stylesheet" href="http://code.jquery.com/ui/1.10.1/themes/base/jquery-ui.css" />
<script src="http://code.jquery.com/jquery-1.9.1.js"></script>
<script src="http://code.jquery.com/ui/1.10.1/jquery-ui.js"></script>
<link rel="stylesheet" href="/resources/demos/style.css" />
<style>
#sortable1, #sortable2 { list-style-type: none; margin: 0; padding: 0 0 2.5em; float: left; margin-right: 10px; }
#sortable1 li, #sortable2 li { margin: 0 5px 5px 5px; padding: 5px; font-size: 1.2em; width: 120px; } </style>
<script>
$(function() {
$( "#sortable1,#sortable2" ).sortable({
connectWith: ".connectedSortable",
revert: true
});
$( "#draggable" ).draggable({
connectToSortable: ".connectedSortable",
helper: "clone",
revert: "invalid",
cursor: 'move'
});
$( "ul, li" ).disableSelection();
});
</script>
</head>
<body>
<ul>
<li id="draggable" class="ui-state-highlight">Новый товар</li>
</ul>
<ul id="sortable1" class="connectedSortable">
<li class="ui-state-default">Товар 1-1</li>
<li class="ui-state-default">Товар 1-2</li>
<li class="ui-state-default">Товар 1-3</li>
<li class="ui-state-default">Товар 1-4</li>
<li class="ui-state-default">Товар 1-5</li>
</ul>
<ul id="sortable2" class="connectedSortable">
<li class="ui-state-highlight">Товар 2-1</li>
<li class="ui-state-highlight">Товар 2-2</li>
<li class="ui-state-highlight">Товар 2-3</li>
<li class="ui-state-highlight">Товар 2-4</li>
<li class="ui-state-highlight">Товар 2-5</li>
</ul>
</body>
</html>
|
А как нибудь можно проверить отсутствие перетаскиваемого товара в диве?
Что бы повторов не было? |
непонял, все элементы в одном экземпляре, какае такие повторы там могут быть ?
|
Все, спасибо, как раз сейчас сам разобрался с вопросом!
Спасибо за помощь! |
| Часовой пояс GMT +3, время: 20:10. |