Вы можете определить функцию, как показано ниже.Посмотрите демоверсию здесь .
function drop(selector, a) {
$(selector).droppable({
accept: a,
activeClass: 'drop-active',
hoverClass: 'dropareahover',
drop: function(event, ui) {
var targetId = $(this).attr("id");
$("#" + targetId).each(function() {
$(this).append(ui.draggable.text());
});
}
});
}
$(document).ready(function() {
$(".list").draggable({
helper: 'clone',
cursor: 'hand',
revert: true,
drag: function(ev, ui) {
dragId = $(this).attr('id');
}
});
drop("#td1", '#1');
drop("#td2", '#1');
drop("#td3", '#2');
drop("#td4", '#2');
drop("#td5", '#3');
drop("#td6", '#3');
drop("#td7", '#4');
drop("#td8", '#4');
});
РЕДАКТИРОВАТЬ Более компактный раствор, используя массивы ниже.Живая дема здесь .
function drop2(teacher, subjects) {
$.each(subjects, function(index, subject) {
$(subject).droppable({
accept: teacher,
activeClass: 'drop-active',
hoverClass: 'dropareahover',
drop: function(event, ui) {
var targetId = $(this).attr("id");
$("#" + targetId).each(function() {
$(this).append(ui.draggable.text());
});
}
});
});
}
$(document).ready(function() {
$(".list").draggable({
helper: 'clone',
cursor: 'hand',
revert: true,
drag: function(ev, ui) {
dragId = $(this).attr('id');
}
});
drop2('#1',['#td1', '#td2']);
drop2('#2',['#td3', '#td4']);
drop2('#3',['#td5', '#td6']);
drop2('#4',['#td7', '#td8']);
});