3

我正在使用 knockout.js 创建一个应用程序,使用 knockout-sortable 进行拖放可排序列表。有一个垂直列表,每个项目内部都有一个水平列表。垂直列表表现得很好,但是每当我尝试在水平列表中拖动一个项目时,它会相对于被拖动的项目向上或向下推动该列表中的其余项目。水平列表定义如下:

<div style="float: left" data-bind="sortable: { template: 'levelTmpl', data: $data.levels, beforeMove: $root.verifyMove, afterAdd: showLevel, beforeRemove: hideLevel, options: { containment: 'parent' } }"></div>
<script id="levelTmpl" type="text/html">
    <div class="container item" style="display: inline-block">
    <div style="float: right"><span class="ui-button" data-bind="click: $parent.removeLevel">[x]</span></div>
    <input data-bind="value: name"/><br/>
    <div style="clear: both"></div>
    <textarea cols="35" rows="4" data-bind="value: description"> </textarea><br/>
    <textarea cols="35" rows="4" data-bind="value: canned"> </textarea>
    </div>
</script>

您可以在此处查看完整的应用程序:
链接不再存在

我已经尝试了我找到的所有建议,包括http://bugs.jqueryui.com/ticket/6702上的建议,但到目前为止,没有任何效果。我真的很想让水平可排序列表工作,所以如果有人有任何建议,我将不胜感激。

4

1 回答 1

0

仅供参考https://github.com/rniemeyer/knockout-sortable只是 jquery ui 可排序的包装器。

为了不混淆列表,请在可排序元素上使用 connectClass。

于 2014-02-28T18:52:33.537 回答