私はJQueryを初めて使用し、Web上の一連のチュートリアルとこのWebサイトの回答に取り組みましたが、これを解決できず、助けていただければ幸いです。
一連のドラッグ可能およびドロップ可能な div がある関数を作成しようとしています。それぞれが関連するスロットにのみ受け入れられます。
スロットに小さな「x」が表示されると、ユーザーはクリックしてドラッグ可能な要素を親に戻すことができます。
私はほとんどそこにいます このコードはほとんど機能します-スロットがあり、ドラッグ可能な要素があります。停止すると「x」が表示されますが、「x」を機能させてdivをホームに戻すことができます。
どんな助けでも感謝します。これが私のコードです:
<!doctype html>
<html lang="en">
<head>
Drag and drop</title>
<meta http-equiv="Content-Type" content="text/html;charset=utf-8">
<link rel="stylesheet" type="text/css" href="style.css">
<script type="text/javascript" src="http://ajax.googleapis.com/ajax/libs/jquery/1.5.0/jquery.min.js"></script>
<script type="text/javascript" src="http://ajax.googleapis.com/ajax/libs/jqueryui/1.8.9/jquery-ui.min.js"></script>
<script type="text/javascript">
$( init );
function init() {
// Reset
$('#defPile').html( '' );
$('#defSlots').html( '' );
$('#gkPile').html( '' );
$('#gkSlots').html( '' );
// Create defenders
var numbers = [ 1, 2, 3, 4 ];
var position = 'd';
for ( var i=0; i<4; i++ ) {
$('<div>' + numbers[i] + "<span class='undo' style='display:none'>x</span> </div>").data( 'number', numbers[i] ).data( 'position', 'd' ).attr( 'id', 'card'+numbers[i] ).appendTo( '#defPile' ).draggable( {
containment: '#content',
stack: '#defPile div',
revert: 'invalid',
stop: function(event, ui){
$(this).find('.undo').show();
$(this).draggable('option','revert','invalid');
}
} );
}
// Create the pile gk cards
var numbers = [ 1, 2, 3, 4, 5 ];
var position = 'g';
for ( var i=0; i<5; i++ ) {
$('<div>' + numbers[i] + "<span class='undo' style='display:none'>x</span></div>").data( 'number', numbers[i] ).data( 'position', 'g' ).attr( 'id', 'card'+numbers[i] ).appendTo( '#gkPile' ).draggable( {
containment: '#content',
stack: '#gkPile div',
revert: 'invalid',
stop: function(event, ui){
$(this).find('.undo').show();
$(this).draggable('option','revert','invalid');
}
} );
}
// Create the def slots
var words = [ 'def' ];
$('<div>' + 'defender' + '</div>').data( 'number', i ).appendTo( '#defSlots' ).droppable( {
accept: '#defPile div',
hoverClass: 'hovered',
drop: handleCardDrop
} );
// Create the gk slots
var words = [ 'gk' ];
$('<div>' + 'goalie' + '</div>').data( 'number', i ).appendTo( '#gkSlots' ).droppable( {
accept: '#gkPile div',
hoverClass: 'hovered',
drop: handleCardDrop
} );
}
function handleCardDrop(event,ui ) {
ui.draggable.draggable('option','revert',false);
if (!ui.draggable.data("originalPosition")) {
ui.draggable.data("originalPosition",
ui.draggable.data("draggable").originalPosition);
$(this).droppable( 'disable' );
}
var slotNumber = $(this).data( 'number' );
var cardNumber = ui.draggable.data( 'number' );
var position = ui.draggable.data( 'position' );
//ui.draggable.addClass( 'correct' );
ui.draggable.draggable( 'disable' );
//$(this).droppable( 'disable' );
ui.draggable.position( { of: $(this), my: 'left top', at: 'left top' } );
ui.draggable.draggable( 'option', 'revert', false );
//$(this).draggable('option','revert','invalid');
}
$('.gkPile').find('.undo').click(function(i, e) {
var $div = $(this).parent();
revertDraggable($div);
});
$('.defPile').find('.undo').click(function(i, e) {
var $div = $(this).parent();
revertDraggable($div);
});
function revertDraggable($selector) {
$selector.each(function() {
var $this = $(this),
position = $this.data("originalPosition");
if (position) {
$this.animate({
left: position.left,
top: position.top
}, 500, function() {
$this.data("originalPosition", null);
});
}
});
$selector.find('.undo').hide();
}
</script>
</head>
<body>
<div id="content">
<div id="defPile"> </div>
<div id="defSlots"> </div>
<div id="gkPile"> </div>
<div id="gkSlots"> </div>
</div>
</div>
</body>
</html>
http://www.lfc-predictions.co.uk/dragtest/index3.phpに実例があります。