Sto tentando di creare un elenco ordinato di elementi selezionabili e trascinabili con il plug-in Sortable jQuery UI versione 1.8.16. Tuttavia, continuo a ricevere l'errore $("#ol-id ol").sortable is not a function
, con "id-id" che è l'id della lista. Il mio codice è il seguente:jQuery ordinabile non è una funzione
//Sorting stuff
if($("#li-id li").size()>1) {
$("#ol-id ol").sortable({
revert: true,
axis: 'y',
containment: 'parent',
cursor: 'move',
handle: 'div.link_div',
smooth: false,
opacity: 0.7,
tolerance: 'pointer',
start: function(){
$("#ol-id").removeClass("bottom_dragged");
},
update: function(){
$("#ol-id ol").sortable({disabled : true});
$("#saving_indicator").html("saving...")
$("#saving_indicator").show();
//do other stuff...
}
})
}
Stranamente, l'errore si presenta in Firebug come sulla linea con update: function(){
.
Ho verificato che questa funzione viene chiamata dopo aver caricato sia la pagina che la libreria dell'interfaccia utente jQuery. Sto includendo jquery-1.6.2.min.js e jquery-ui-1.8.16.custom.min.js nell'intestazione. Inoltre, ho verificato che tutti i nomi ID sono corretti e corrispondono alle loro controparti HTML.
Quindi, se non si tratta di elementi mancanti relativi alle risorse, qual è la causa del problema?
EDIT: ecco la mia intestazione HTML:
<link href="/_css/styles.css?mod=1317745564" type="text/css" rel="stylesheet">
<link href="/_javascript/qtip/jquery.qtip.min.css?mod=1315947301" type="text/css" rel="stylesheet">
<script type="text/javascript" async="" src="http://www.google-analytics.com/ga.js">
<script type="text/javascript" async="" src="http://www.google-analytics.com/ga.js">
<script src="https://ajax.googleapis.com/ajax/libs/jquery/1.6.2/jquery.min.js" type="text/javascript">
<script type="text/javascript" src="https://ajax.googleapis.com/ajax/libs/jquery/1.6.2/jquery.min.js">
<link rel="stylesheet" type="text/css" href="https://ajax.googleapis.com/ajax/libs/jqueryui/1.8.16/themes/start/jquery-ui.css">
<link rel="stylesheet" type="text/css" href="http://ajax.googleapis.com/ajax/libs/jqueryui/1.8.16/themes/le-frog/jquery-ui.css">
<script src="https://ajax.googleapis.com/ajax/libs/jqueryui/1.8.16/jquery-ui.js" type="text/javascript">
<script src="/_javascript/sets.js?mod=1320080042" type="text/javascript"> //Sorting stuff code is here
<script type="text/javascript" src="http://dev.selfcheck.vudat.msu.edu/_javascript/jquery.jsonp.js">
<script type="text/javascript" src="http://dev.selfcheck.vudat.msu.edu/_javascript/jquery.form.js">
<script type="text/javascript" src="http://dev.selfcheck.vudat.msu.edu/_javascript/qtip/jquery.qtip.min.js">
<link href="/_css/ui/ui.core.css?mod=1315947279" type="text/css" rel="stylesheet">
<link href="/_css/ui/ui.theme.css?mod=1315947280" type="text/css" rel="stylesheet">
Hai inserito l'interfaccia utente di jQuery dopo jQuery? –
Prova '$ (this) .sortable ({disabled: true});' all'interno 'update', solo per verificare. – yoda
Ho verificato che jQuery UI viene caricata dopo jQuery e il problema è ancora qui. Inoltre, l'uso di "this" al posto degli id appropriati non rimuove l'errore. Grazie per i suggerimenti però! – CodeRedd