1

HTMLドキュメントに2つのドラッグ可能なdivがあり、2つのドラッグ可能なdivの横に1つのドロップ可能なdivがあります。

ドラッグ可能なdivの1つをドロップ可能なdivにドラッグすると、ドロップ可能なdivにテキストが表示され、ドラッグ可能なdivが元の場所に戻ります。

私の質問は、ドロップ可能なdivにドロップしたドラッグ可能なdivに応じて、ドロップ可能なdivのテキストをどのように変更できるかということです。

これが理にかなっていることを願っています。以下が私のコードです。

どうもありがとう

<!doctype html>
<html lang="en">
<head>
<meta charset="utf-8" />
<title>jQuery UI Droppable - Revert draggable position</title>
<link rel="stylesheet" href="http://code.jquery.com/ui/1.10.1/themes/base/jquery-ui.css" />
<script src="http://code.jquery.com/jquery-1.9.1.js"></script>
<script src="http://code.jquery.com/ui/1.10.1/jquery-ui.js"></script>
<style>
#draggable, #draggable2 { width: 100px; height: 100px; padding: 0.5em; float: left; margin: 10px 10px 10px 0; }
#draggable, #draggable1 { width: 100px; height: 100px; padding: 0.5em; float: left; margin: 10px 10px 10px 0; }
#droppable { width: 150px; height: 150px; padding: 0.5em; float: left; margin: 10px; }
</style>
<script>
$(function() {
$( "#draggable" ).draggable({ revert: "valid" });
$( "#draggable1" ).draggable({ revert: "valid" });
$( "#droppable" ).droppable({
activeClass: "ui-state-hover",
hoverClass: "ui-state-active",
drop: function( event, ui ) {
$( this )
.addClass( "ui-state-highlight" )
.find( "p" )
.html( "Dropped!" );
}
});
});
</script>
</head>
<body>
<div id="draggable" class="ui-widget-content">
<p>I revert when I'm dropped</p>
</div>

<div id="draggable1" class="ui-widget-content">
<p>I revert when I'm dropped</p>
</div>

<div id="droppable" class="ui-widget-header">
<p>Drop me here</p>
</div>
</body>
</html>
4

2 に答える 2

3

提供した例を使用して、これを試してください。

$(function() {
    $( "#draggable" ).draggable({ revert: "valid" });
    $( "#draggable1" ).draggable({ revert: "valid" });
    $( "#droppable" ).droppable({
        activeClass: "ui-state-hover",
        hoverClass: "ui-state-active",
        drop: function( event, ui ) {
            $( this )
            .addClass( "ui-state-highlight" )
            .find( "p" )
            .html( ui.draggable[0].id );
        }
    });
});

デモ:http: //jsfiddle.net/dirtyd77/SLGdE/23/

于 2013-03-14T16:42:28.023 に答える
0

次のようにdraggable、オブジェクトから要素(ドラッグされた要素)のIDを取得できます。ui

drop: function( event, ui ) {
    ui.draggable[0].id
}

フィドル

例では、完全なdropコールバックは次のようになります。

drop: function (event, ui) {
    $(this)
        .addClass("ui-state-highlight")
        .find("p")
        .html("Dropped! " + ui.draggable[0].id);
}
于 2013-03-14T16:39:07.870 に答える