我一直在查看 jQueryUI 的 Draggable 和 Droppable 的文档。我找到了各种方法可以将列表拖放到另一个列表,但不是两种方式?
我的情况是,我有 2 个列表:
<div id='attached'>
<ul>
<li id='12'>An item</li>
<li id='48'>An item</li>
<li id='183'>An item</li>
</ul>
</div>
<div id='non-attached'>
<ul>
<li id='36'>An item</li>
<li id='873'>An item</li>
<li id='1639'>An item</li>
</ul>
</div>
如果将一个项目从列表 1 放到列表 2 中,则应该执行 AJAX url - 比如
hello.asp?action=add&id=48
如果一个人从列表 2 中删除一个项目到列表 1 另一个 AJAX url 应该被执行 - 比如
hello.asp?action=remove&id=48
这有可能吗?:) 这将使我的脚本界面更容易:)
注意:我已经熟悉 jQueryUI,但 droppable 和 draggable 对我来说都是新的。至少到现在为止:)
编辑:
<ul id='attached'>
<li id='itemID_12'>An item</li>
<li id='itemID_48'>An item</li>
<li id='itemID_183'>An item</li>
</ul>
<ul id='non-attached'>
<li id='itemID_36'>An item</li>
<li id='itemID_873'>An item</li>
<li id='itemID_1639'>An item</li>
</ul>
$(function() {
$('#attached').sortable({ dropOnEmpty: true, items: 'li:not(.ui-state-disabled)', cursor: 'pointer', update: function(event, ui) { }, connectWith: '#non-attached' }).disableSelection();
$('#non-attached').sortable({ dropOnEmpty: true, items: 'li:not(.ui-state-disabled)', cursor: 'pointer', update: function(event, ui) { }, connectWith: '#attached' }).disableSelection();
};
现在我只需要通过 AJAX 通过 update: {} 获取正确的序列化数据吗?
编辑:
知道了!
var order = $('#attached').sortable('serialize',{key:'string'});
$.ajax({
type: 'POST',
cache: false,
contentType: 'application/x-www-form-urlencoded; charset=UTF-8',
url: 'functions.asp?a=helloworld',
data: order
});
现在,当我在functions.asp中请求.form(“字符串”)时,我得到一系列ID,例如“25、28、31、94、95”.. :)