To jest trochę niejasny problem, ale używam jQuery Sortables i próbuję uzyskać dwie dobrze połączone ze sobą listy, gdy jeden z nich jest ustawiony jako fixed
. Wszystko działa dobrze, dopóki nie przewiniesz strony tak, że dwie listy zostaną umieszczone jeden na drugim. Wtedy wydaje się, że listy nie mają pojęcia, który z nich powinien otrzymać przedmiot, który jest przeciągany, co oznacza, że pojawia się mnóstwo zdenerwowania, które pojawia się/znika na każdej liście.Radzenie sobie z nakładającymi się listami sortowalnych jQuery
Wygląda na to, że obie listy obsługują zdarzenia myszy/sortowania, ponieważ element, który jest przeciągany, znajduje się technicznie na obu listach, ale chcę, aby nałożona lista (np. position: fixed
) połknęła zdarzenia tak, że podstawowa lista nie próbuje odebrać przedmiotu.
Oto minimalne przykładowy kod:
<html>
<head>
<script type="text/javascript" src="http://ajax.googleapis.com/ajax/libs/jquery/1.4.3/jquery.min.js"></script>
<script type="text/javascript" src="http://ajax.googleapis.com/ajax/libs/jqueryui/1.8.6/jquery-ui.min.js"></script>
<style type="text/css">
ul { list-style-type: none; padding: 0; float: left; }
li { margin: 5px; padding: 5px; width: 500px; border: solid 1px #F00; background-color: #FFF; }
#overlayed { position: fixed; top: 0; background-color: #000; margin: 20px; padding: 10px; }
#overlayed li { width: 50px; float: left; }
</style>
<script type="text/javascript">
$(function() {
$("ul").sortable({ connectWith: "ul", opacity: 0.6 }).disableSelection();
});
</script>
</head>
<body>
<div id="overlayed">
<ul>
<li>Item X</li>
<li>Item Y</li>
<li>Item Z</li>
</ul>
</div>
<br/><br/><br/><br/><br/>
<ul>
<li>Item 01</li>
<li>Item 02</li>
<li>Item 03</li>
<li>Item 04</li>
<li>Item 05</li>
<li>Item 06</li>
<li>Item 07</li>
<li>Item 08</li>
<li>Item 09</li>
<li>Item 10</li>
<li>Item 11</li>
<li>Item 12</li>
<li>Item 13</li>
<li>Item 14</li>
<li>Item 15</li>
<li>Item 16</li>
<li>Item 17</li>
<li>Item 18</li>
<li>Item 19</li>
<li>Item 20</li>
<li>Item 21</li>
<li>Item 22</li>
<li>Item 23</li>
<li>Item 24</li>
<li>Item 25</li>
<li>Item 26</li>
<li>Item 27</li>
<li>Item 28</li>
<li>Item 29</li>
<li>Item 30</li>
</ul>
</body>
</html>
Więc pytanie brzmi, jak mogę to naprawić?
Zanotuj kod biblioteki, dowiedz się, jak działa używana funkcja, a następnie powinieneś być w stanie rozwiązać problem. – aaaaaaaaaaaa