jquery draggable droppable with sortable

时间:2013-11-14 21:22:36

标签: javascript jquery jquery-ui drag-and-drop jquery-ui-droppable

我正在尝试这样做,以便当我将所有单词放在底部的瓷砖中时,我可以在“最喜欢我和最不喜欢我”的可放置区域之间对它们进行排序。现在,我可以将它们拖放到不同的盒子中,但它会在一个可放置的区域中将两个可拖动的对象放在一起。我希望它可以推动另一个可拖动的开箱即用,并且不允许两个可拖动区域位于相同的可投放区域,同时仍允许用户在出错或想要使用它们时改变主意。请找到以下代码:

HTML

<div id="content">
  <div id="cardPile">
  <div id="question1">Spontaneous</div>
  <div id="question2">Decisive</div>
  <div id="question3">Realistic</div>
  <div id="question4">Logical</div>
  </div>

  <div id="cardSlots">
  <div>Most Like Me</div>
  <div>2nd Most Like Me</div>
  <div>3rd Most Like Me</div>
  <div>Least Like Me</div>

  </div>

</div>

CSS

@charset "utf-8";
/* CSS Document */

/* Add some margin to the page and set a default font and colour */

body {margin: 30px;font-family: "Tahoma", serif;line-height: 1.8em;color: #333;}

/* Give headings their own font */

h1, h2, h3, h4 {
  font-family: Century Gothic, sans-serif;
  font-weight:normal;
}

/* Main content area */

#content {
  margin: 65px 0px;
  text-align: center;
  -moz-user-select: none;
  -webkit-user-select: none;
  user-select: none;
}

/* Header/footer boxes */

.wideBox {
  clear: both;
  text-align: center;
  margin: 70px;
  padding: 10px;
  background: #ebedf2;
  border: 1px solid #333;
}

.wideBox h1 {
  font-weight: bold;
  margin: 20px;
  color: #666;
  font-size: 1.5em;
}

/* Slots for final card positions */

#cardSlots {
  margin: 10px auto 0 auto;
  background:#D9F2FF;
}

/* The initial pile of unsorted cards */

#cardPile {
  margin: 0 auto;
  background: #ffffff;
}

#cardSlots {
  width: 910px;
  height: 55px;
  padding: 20px;
  border: 1px solid #999;
  -moz-border-radius: 10px;
  -webkit-border-radius: 10px;
  border-radius: 10px;
  -moz-box-shadow: 0 0 .3em rgba(0, 0, 0, .8);
  -webkit-box-shadow: 0 0 .3em rgba(0, 0, 0, .8);
  box-shadow: 0 0 .3em rgba(0, 0, 0, .8);
}
 #cardPile {
width: 910px;
  height: 55px;
  padding: 20px;
  -moz-border-radius: 10px;
  -webkit-border-radius: 10px;
  border-radius: 10px;
 }
/* Individual cards and slots */

#cardSlots div, #cardPile div {
  float: left;
  width: 195px;
  height: 20px;
  padding: 10px;
  padding-top: 10px;
  padding-bottom: 20px;
  border: 2px solid #999;
  -moz-border-radius: 10px;
  -webkit-border-radius: 10px;
  border-radius: 10px;
  margin: 0 0 0 10px;
  background: #fff;
}

#cardSlots div:first-child, #cardPile div:first-child {
  margin-left: 0;
}

#cardSlots div.hovered {
  background: #aaa;
}

#cardSlots div {
  border-style: dashed;
}

#cardPile div {
  background: #009;
  color: #fff;
  font-size: 20px;
  text-shadow: 0 0 3px #000;
}

#cardPile div.ui-draggable-dragging {
  -moz-box-shadow: 0 0 .5em rgba(0, 0, 0, .8);
  -webkit-box-shadow: 0 0 .5em rgba(0, 0, 0, .8);
  box-shadow: 0 0 .5em rgba(0, 0, 0, .8);
}

的Javascript

$(document).ready(function(){    

$( init );

function init() {
  // Create the pile of shuffled cards
  {
    $('#cardPile div').draggable( {
      containment: '#content',
      stack: '#cardPile div',
      cursor: 'move',
      revert: true
    } );
  }

  // Create the card slots
  {
    $('#cardSlots div').droppable( {
      accept: '#cardPile div',
      hoverClass: 'hovered',
      drop: handleCardDrop
    } );



  }

function handleCardDrop( event, ui ) {
    var slotNumber = $(this);
    var cardNumber = ui.draggable;  

    if ( cardNumber1 == cardNumber1 ) {
        ui.draggable.addClass ( 'correct' );
        ui.draggable.position( {of: $(this), my: 'left top', at: 'left top' } );
        ui.draggable.draggable( 'option', 'revert', false );
    }
}

}



});

1 个答案:

答案 0 :(得分:0)

看看这个:working demo

$(document).ready(function () {

$(init);

function init() {

    $('#cardSlots').sortable({placeholder: "ui-state-highlight"});
    // Create the pile of shuffled cards
    {
        $('#cardPile div').draggable({
            containment: '#content',
            stack: '#cardPile div',
            cursor: 'move',
            connectToSortable: '#cardSlots'

        });
    }

    // Create the card slots
    {
        $('#cardSlots').droppable({
            accept: '#cardPile',
            hoverClass: 'hovered',
            drop: handleCardDrop

        });}

    function handleCardDrop(event, ui) {
        var slotNumber = $(this);
        var cardNumber = ui.draggable;

        if (cardNumber1 == cardNumber1) {
            ui.draggable.addClass('correct');
            ui.draggable.position({
                of: $(this),
                my: 'left top',
                at: 'left top'
            });

          ui.draggable.draggable('option', 'revert', false);

        }

    }

 }
});