我有一些可拖动的元素
我有一些放置字段,我可以轻松地将元素放置到可放置区域中。但是无法将元素从一个放置的字段拖放到另一个字段
这是Jsfiddle Demo
查看小提琴如何工作
这是jQuery
$(function () {
$(".selectorField").draggable({
containment: $('body'),
helper: "clone",
stack: "div",
cursor: "move",
cancel: null
});
function makeDraggable($sel) {
$sel.draggable({
containment: $('.droppedFields'),
cursor: "move",
});
$sel.find('.resize_box').resizable({
handles: {
'e': '.ui-resizable-e'
}
});
}
var i = 1;
$("#AddSec").click(function () {
$("<div />", {
"class": "wrapper"
})
.append($('<span />', {
"class": "DelSection",
"data-target": "#Section" + i
}).html('(-)Remove'))
.appendTo("#data");
$("<div />", {
"class": "SecStyle",
id: "Section" + i
})
.append($("<div/>").attr('class', 'well droppedFields').droppable({
accept: ":not(.not_clone)",
drop: function (event, ui) {
var draggable = ui.draggable;
draggable = draggable.clone();
draggable.addClass('not_clone');
draggable.appendTo(this);
$(ui.draggable).hide();
draggable.click(function (e) {
if ($(this).hasClass('is_sort')) {
$('.selectorField').removeClass('is_sort');
e.preventDefault();
return;
}
if (!$(e.target).is('.ui-resizable')) {
// alert("First");
$(this).remove();
$(ui.draggable).show();
}
});
}
}).resizable({
handles: 'e'
}))
.appendTo("#data");
$(".droppedFields").sortable({
start: function () {
$('.selectorField').addClass('is_sort');
}
}).disableSelection();
i++;
});
var is_sort = false;
//delete the columns from section
//delete the section
$("#data").on('click', '.DelSection', function () {
var targetSection = $(this).data('target');
$(targetSection).remove();
$(this).parent().remove();
});
});
最佳答案
通过改变解决自己
$(".droppedFields").sortable({
start: function () {
$('.selectorField').addClass('is_sort');
}
}).disableSelection();
至
$(".droppedFields").sortable({
start: function () {
$('.selectorField').addClass('is_sort');
},
connectWith: ".droppedFields"
}).disableSelection();
Demo Fiddle
关于javascript - 无法在放置的字段之间放置元素,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/27068631/