0

我对 JQuery 很陌生,并且已经完成了网络上的一系列教程和本网站上的答案,但我无法解决这个问题,希望能提供任何帮助。

我正在尝试创建一个函数,其中有一系列可拖动和可放置的 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

1

看了看页面,看起来你很接近!只需将点击事件的选择器从选择器更改为id选择器

$('#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);
});

对于 jQuery 选择器,使用#作为 ids 和. 上课。

于 2013-06-21T19:52:13.487 回答