【发布时间】:2014-12-03 18:29:24
【问题描述】:
我想有一个顶级的可放置区域,当用户开始将一些元素拖到这个区域时,我想将它分成不同的部分(北、东、南和西等)并允许用户放置在其中任何一个。
最好的方法是什么?
这是我尝试做的:
HTML
<div class='main_droppable_area'>
<div class='drop_area north'></div>
<div class='drop_area east'></div>
<div class='drop_area south'></div>
<div class='drop_area west'></div>
</div>
<div class='draggable_area'>
</div>
CSS
.main_droppable_area {
top: 50px;
left: 50px;
right: 50px;
height: 200px;
border: 1px dashed blue;
position: absolute;
}
.drop_area {
position: absolute;
border: 1px dashed blue;
background-color: #eff;
opacity: 0.5;
filter: alpha(opacity=50);
display: none;
}
.drop_area.active {
opacity: 1;
filter: alpha(opacity=100);
}
.drop_area.north {
top: 0px;
left: 0px;
right: 0px;
height: 50px;
}
.drop_area.south {
bottom: 0px;
left: 0px;
right: 0px;
height: 50px;
}
.drop_area.west {
top: 50px;
left: 0px;
bottom: 50px;
width: 50px;
}
.drop_area.east {
top: 50px;
right: 0px;
bottom: 50px;
width: 50px;
}
.draggable_area {
position: absolute;
top: 300px;
left: 50px;
background-color: blue;
width: 50px;
height: 50px;
}
JavaScript
$(document).ready(function() {
$( '.draggable_area' ).draggable();
$('.main_droppable_area').droppable({
accept: '.draggable_area',
over: function() {
console.log('main_droppable_area - over');
$('.drop_area').show();
},
out: function() {
console.log('main_droppable_area - out');
$('.drop_area').hide();
}
});
$('.drop_area').droppable({
accept: '.draggable_area',
over: function() {
$(this).addClass('active');
console.log('drop_area - over');
},
out: function() {
$(this).removeClass('active');
console.log('drop_area - out');
}
});
});
但不幸的是,这段代码并不总是有效...例如,如果我尝试从主要可放置区域之外拖动项目,它就无效。
但是,如果我将项目拖放到该区域并再次开始拖动它,它就会起作用。
我的代码有问题吗?这是我的 JSFiddle example
更新
感谢 T J 的解决方案...这里是 JS fiddle 的工作示例
【问题讨论】:
-
“它不起作用”到底是什么意思..?
-
我无法获得“over”和“out”工作的代码。打开控制台并尝试将蓝色框拖到可放置区域。当您移动到北/东/南/西区域时,它应该会捕捉到溢出/溢出事件,但它不会
标签: jquery jquery-ui jquery-ui-draggable jquery-ui-droppable