多次初始化jQuery可排序的成本

时间:2015-05-19 20:51:59

标签: javascript jquery jquery-ui

我目前正在使用表单构建器并使用jQuery sortable我遇到的问题是在编辑当前字段时从列表项中删除事件处理程序。然后在保存问题输入后重新初始化它。

目前我正在运行jQuery Sortable的初始化。

$('.sortable').sortable({
         placeholder: "sortable-placeholder",
         items : ".is-sortable"
    });

然后在编辑时运行destroy方法以删除可排序的功能

$('.sortable').sortable('destroy');

然后保存重新初始化可排序的问题。

 $('.sortable').sortable({
         placeholder: "sortable-placeholder",
         items : ".is-sortable"
    });

我尝试添加和删除.is-sortable类,以防止在类不存在时进行排序,但由于事件处理程序已附加到父容器,因此该项仍可排序

有没有更好的方法解决jQuery可排序的事件处理程序

如果没有,那么在每个"添加,"编辑"中删除和重新初始化插件的成本是多少?并且,"保存"一个领域。

2 个答案:

答案 0 :(得分:0)

您可以使用cancel方法代替destroy。 cancel方法停止当前的排序操作。

  

取消当前可排序的更改并将其恢复为当前排序开始之前的状态。在停止和接收回调函数中很有用。

http://api.jqueryui.com/sortable/#method-cancel

现在取消编辑操作。我想,这会有所帮助。

答案 1 :(得分:0)

你有启用和禁用也可以做这项工作,那么你不必每次都回忆起它:

http://api.jqueryui.com/sortable/#method-disable