0

私は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に実例があります。

4

1 に答える 1