我有一个从 Ajax 请求动态填充的 jQuery UI 可排序列表元素。
目前,工作流程进行
- 用户单击按钮,列表被填充并按指定设置排序。
- 用户点击另一个按钮,
- 通过调用删除现有列表
<li>
元素jQuery.empty()
- 新数据值被插入到新的
<li>
列表元素中并附加到<ul>
列表中 - 可排序列表通过 $("#sortable").sortable("refresh"); 刷新
- 通过调用删除现有列表
给定一个可排序列表对象$("#avail_list").sortable( ... );
,我希望draggable
根据其他元素中的现有值禁用特定列表元素的属性并将不透明度设置为 0.5。
为此,我有以下功能:
var disabled = [];
var appendString = ""
if (avail.length > 0) {
for (var i = 0; i < avail.length; i++) {
//check if current list element exists in existing value list. True results
//in grayed out and non-draggable element
compareMatch = checkMatch(avail[i], compare);
if (compareMatch)
disabled.push(list + "open_" + avail[i].id);
appendString += "<li id = "+ list + "open_" + avail[i].id +
" class = 'avail_list_element'><img class = 'logo' src = /static/images/vendor_logo/" + avail[i].icon + " /></li>"
}
$("#avail_list").append(appendString);
}
$("#avail_list").sortable("refresh");
if (disabled.length > 0)
disableDraggable(disabled);
function disableDraggable(elements){
for (var i = 0; i < elements.length; i++) {
console.log(elements[i])
$("#" + elements[i]).sortable("disable");
$("#" + elements[i]).fadeTo("fast", 0.5);
}
}
但是,这会导致错误
Error: cannot call methods on sortable prior to initialization;
attempted to call method 'disable'
既然我refresh
在禁用元素之前调用了可排序列表,那么如何sortable
不初始化对象呢?