0

ここでは、jQuery でドラッグ アンド ドロップを使用しています。

データベースから一連の質問と一連の回答を配列 (article->question、article->answers) で取得し、回答を質問テキスト ボックスにドラッグ アンド ドロップします。ページを更新すると、ドラッグされた値は、ドロップした特定のテキスト ボックスではなく元の場所に移動します。

ここで私のコーディング。

  <html>
<head>
   <meta charset="utf-8" />
    <title>jQuery UI Draggable - Default functionality</title>
    <link rel="stylesheet" href="http://code.jquery.com/ui/1.10.3/themes/smoothness/jquery-  ui.css" />
  <script src="http://code.jquery.com/jquery-1.9.1.js"></script>
  <script src="http://code.jquery.com/ui/1.10.3/jquery-ui.js"></script>
  <!--<link rel="stylesheet" href="/resources/demos/style.css" />  -->
 <style>
 /*#draggable { width: 50px; height: 20px; padding: 0.5em; } */
.drag_ans {
background: none repeat scroll 0 0 transparent;
border: 0 none;
width: 100px;
}
#draggable {
width: 50px;
height: 20px;
background: white;
}
#droppable {
float: left;
margin: 50px;
width: 500px;
height: 300px;
 border: green;
}

   #ques {
background: none repeat scroll 0 0 #FFFFFF;
padding: 10px;
width: 100px;

  }
 </style>

   <script>
    $(document).ready(function(){
    $("#answer").click(function(){
 // alert('find a score');
    });
      });
  </script>
 </head>

<body>
<div class="container_inner">

<?php

 foreach($data as $article)
  {
   echo "<p>";
    echo "<b>";echo $article->article_name;
echo"</b>";
echo "</p>";
echo "<p>";
     echo $article->description;
  echo "</p>";
echo $article->video; echo "<br>";
    }
   ?>
  <?php
  $add=1;
foreach($question as $article)
     {
?>
    <!--    <div id="drop">  -->

   <p>
 <?php echo $article->question; ?>
 <input type ="text" id="ques_<?php echo $add; ?>" name="" class="ui-widget-content" />
  </p>
  <!--</div>  -->
<?php 
$add++;
    }
   ?>  



   <?php
      $counter=1;
    foreach($question as $article)
      {
?>
 <script>
      $(function() {

       $("#draggable_<?php echo $counter; ?>").draggable({ revert: 'invalid' });

     $("#ques_<?php echo $counter; ?>").droppable({

   drop: function( event, ui ) {

      $(this).addClass( "ui-state-highlight" ).find( "p" ).html( "Dropped!" );
      }
      });
       });
       </script> 
    <div id="draggable_<?php echo $counter; ?>" class="ui-widget-content drag_ans">
   <p>
    <?php echo $article->answer; ?>
    </div>
  </p>
 <?php 
$counter++;
  }
 ?>  

  <p> <input class="green_but" type="submit" name="NEW_SUBMIT" value="Submit" id="answer"/> </p>
  </div>
</body>
  </html>

ドラッグ アンド ドロップは正常に機能し、ページの値を更新すると、質問テキスト ボックスにすべて空の値が表示されます。質問テキストボックスをドロップした後、この回答はDBに保存する必要があるため、jqueryで質問と回答を検証する方法。また、送信ボタンをクリックすると、質問への回答が間違っている場合、スコアが減少するはずです。例: ユーザーの回答が 10 点中 4 点の正解を設定した場合、スコアは 10 点中 4 点になります。

4

1 に答える 1