gpt4 book ai didi

jquery - 使用 jQuery sortable 检测 drop

转载 作者:行者123 更新时间:2023-12-03 22:22:37 25 4
gpt4 key购买 nike

我正在使用 jQuery Sortable ( http://johnny.github.io/jquery-sortable/ ) 来显示嵌套列表、移动元素,然后保存最终结果。最终目标是通过拖放功能显示类别和页面来管理站点结构/层次结构。

显示列表、拖放元素以及保存输出都可以正常工作。我现在想检测放置事件以指示哪些元素已被移动。这将帮助我避免在仅移动少数元素的情况下更新整个网站结构。

我的嵌套列表如下所示:

<ol id="structure" class="tree serialization">
<li class="placeholder-children ui-droppable">
LABEL
<ol>
<li class="placeholder-children ui-droppable">LABEL</li>
<li class="placeholder-children ui-droppable">LABEL
<ol>
<li class="placeholder-children ui-droppable">LABEL</li>
</ol>
</li>
</ol>
</li>
</ol>

LI 都是可放置和可拖动的

一切都初始化为:

<script>
$(function ()
{
$("ol.tree").sortable();
})
</script>

现在是困难的部分,我尝试检测放置事件。

下面的根本不起作用:

$( ".placeholder-children" ).droppable({
drop: function( event, ui ) {
alert('dropped');
}
});
});

这个可以工作,但卡住了我的页面:

<script>
$("ol.tree").sortable(
{
group: 'serialization',
onDrop: function (item, container, _super)
{
alert('dropped!');
}
});
</script>

此代码触发了预期的警报,但拖动卡住,我无法再修改列表中的任何内容。就像整个屏幕被卡住一样,我无法再移动或单击任何内容。我需要重新加载页面,然后退出。

注意:如果没有警报,它也会卡住。

有什么想法吗?

更新:我添加了一个 JSfiddle: http://jsfiddle.net/t9mp80yw/但我不知道如何调用 .js 文件以便初始化脚本。我尝试添加托管在我的服务器上的文件,但 jsfiddle 似乎不接受外部文件。

更新2我已经在 Firefox 和 Internet Explorer 上尝试过该脚本,同样的问题。

非常感谢

劳伦特

PS:此处未显示,但 jQuery、jQuery UI、jQuery Sortable 已正确加载

最佳答案

onDrop 函数需要您执行某些操作。

来自http://johnny.github.io/jquery-sortable/#nested

onDrop: function (item, container, _super) {
container.el.removeClass("active")
_super(item)
}

看起来 super 是一个回调,如果您覆盖 onDrop,则需要调用它。将您的 onDrop 函数替换为此函数即可运行。

http://jsfiddle.net/xdjn2wqp/2/

学习新库的最佳方法是粘贴一些工作示例代码并从那里开始。

关于jquery - 使用 jQuery sortable 检测 drop,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/27492525/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com