我刚刚开始使用jQuery UI将div拖动到表格中的列中。我有几个不同的可拖动div,里面有不同的背景颜色和文字,我需要它们能够作为克隆拖到掉落区域。这通过使用jQuery UI的示例购物车代码工作得很好,但是我已经编辑了所以整个对象被拖动而不仅仅是文本,但是由于某种原因这会消除克隆功能,即使我有帮助:克隆。 / p>
这是我的代码:
<script>
$(function() {
$( "ul li" ).draggable({
appendTo: "body",
helper: "clone"});
$( ".day #drag" ).draggable({
appendTo: "body"});
$( ".day" ).droppable({
activeClass: "ui-state-hover",
hoverClass: "ui-state-active",
accept: ":not(.ui-sortable-helper)",
drop: function( event, ui ) {
var targetElem = $(this).attr("id");
$( this ).addClass( "ui-state-highlight" );
$( ui.draggable ).appendTo( this );
}
}).sortable({
items: "li:not(.placeholder)",
sort: function() {
$( this ).removeClass( "ui-state-default" );
}
});
});
</script>
示例列:
<td>
<div id="monday" class="day monday ui-widget-content"></div>
</td>
可拖动元素:
<li><div style="background-color:#<?=$bgColor?>;color:<?=$textColor?>;" id="drag" class="<?=$subject?>"><?=$row['name']?></div></li>
它本质上是一个时间表设置工具。谢谢你的帮助
这是一个供参考的jsFiddle:http://jsfiddle.net/x5T4h/
答案 0 :(得分:3)
不确定它是否符合您的要求,但这是您的良好开端:http://jsfiddle.net/x5T4h/2/
基本上,我删除了第二个draggable
对象声明,并添加了clone函数来复制drop
事件$( ui.draggable ).clone().appendTo( this );
$(function() {
$( "ul li" ).each(function(){
$(this).draggable({
helper: "clone"
});
});
$( ".day" ).droppable({
activeClass: "ui-state-hover",
hoverClass: "ui-state-active",
accept: ":not(.ui-sortable-helper)",
drop: function( event, ui ) {
var targetElem = $(this).attr("id");
$( ui.draggable ).clone().appendTo( this );
}
}).sortable({
items: "li:not(.placeholder)",
sort: function() {
$( this ).removeClass( "ui-state-default" );
}
});
});