Jquery拖放表单隐藏值插入php mysql

Jquery拖放表单隐藏值插入php mysql,php,jquery,mysql,Php,Jquery,Mysql,我正试图用下面的代码创建一个表单,但没有成功。当我将其中一个可拖动项放入“最像我”字段时,我想输入隐藏字段以捕获值1;当可拖动项位于“第二最像我”字段时,捕获值2;对于“第三最像我”字段,捕获值3;对于“最不像我”字段,捕获值4。我将如何使用以下代码创建此示例?我使用PHP和MySQL作为添加到数据库的参考 <!doctype html> <html> <head> <meta charset="utf-8"> <title>Untit

我正试图用下面的代码创建一个表单,但没有成功。当我将其中一个可拖动项放入“最像我”字段时,我想输入隐藏字段以捕获值1;当可拖动项位于“第二最像我”字段时,捕获值2;对于“第三最像我”字段,捕获值3;对于“最不像我”字段,捕获值4。我将如何使用以下代码创建此示例?我使用PHP和MySQL作为添加到数据库的参考

<!doctype html>
<html>
<head>
<meta charset="utf-8">
<title>Untitled Document</title>
<style type="text/css">
/* Add some margin to the page and set a default font and colour */

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

/* Give headings their own font */

h1, h2, h3, h4 {
  font-family: "Lucida Sans Unicode", "Lucida Grande", sans-serif;
}

/* Main content area */

#content {
  margin: 80px 70px;
  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: 50px auto 0 auto;
  background: #ddf;
}

/* The initial pile of unsorted cards */

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

#cardSlots, #cardPile {
  width: 910px;
  height: 120px;
  padding: 20px;
  border: 2px solid #333;
  -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);
}

/* Individual cards and slots */

#cardSlots div, #cardPile div {
  float: left;
  width: 150px;
  height: 78px;
  padding: 10px;
  padding-top: 40px;
  padding-bottom: 0;
  border: 2px solid #333;
  -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: #666;
  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);
}

</style>

<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">

// JavaScript will go here

$( 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 ( cardNumber == cardNumber ) {
        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 );
    }
}



}

</script>
</head>

<body>

<div id="content">
  <div id="cardPile">
  <div>Controlling</div>
  <div>Motivating</div>
  <div>Realistic</div>
  <div>Organized</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>

</body>
</html>

无标题文件
/*在页面上添加一些边距,并设置默认字体和颜色*/
正文{边距:30px;字体系列:“Georgia”,衬线;线条高度:1.8em;颜色:#333;}
/*给标题自己的字体*/
h1,h2,h3,h4{
字体系列:“Lucida Sans Unicode”,“Lucida Grande”,无衬线;
}
/*主要内容区*/
#内容{
利润率:80px 70px;
文本对齐:居中;
-moz用户选择:无;
-webkit用户选择:无;
用户选择:无;
}
/*页眉/页脚框*/
.wideBox{
明确:两者皆有;
文本对齐:居中;
利润率:70像素;
填充:10px;
背景#ebedf2;
边框:1px实心#333;
}
.wideBox h1{
字体大小:粗体;
利润率:20px;
颜色:#666;
字号:1.5em;
}
/*最终卡位置的插槽*/
#卡片槽{
保证金:50px自动0自动;
背景:#ddf;
}
/*未分类卡片的初始堆*/
#卡片堆{
保证金:0自动;
背景:#ffd;
}
#卡片槽,#卡片堆{
宽度:910px;
高度:120px;
填充:20px;
边框:2倍实心#333;
-moz边界半径:10px;
-webkit边界半径:10px;
边界半径:10px;
-moz盒阴影:0.3emrgba(0,0,0,8);
-webkit盒阴影:0.3EMRGBA(0,0,0,8);
盒影:0.3emrgba(0,0,0,8);
}
/*单个卡和插槽*/
#卡片槽分区,#卡片堆分区{
浮动:左;
宽度:150px;
高度:78px;
填充:10px;
填充顶部:40px;
填充底部:0;
边框:2倍实心#333;
-moz边界半径:10px;
-webkit边界半径:10px;
边界半径:10px;
利润率:0.10px;
背景:#fff;
}
#卡片槽分区:第一个孩子,#卡片堆分区:第一个孩子{
左边距:0;
}
#cardSlots分区悬停{
背景:#aaa;
}
#卡槽部{
边框样式:虚线;
}
#卡片堆分区{
背景:#666;
颜色:#fff;
字体大小:20px;
文本阴影:0 0 3px#000;
}
#cardPile div.ui-可拖动-拖动{
-moz盒阴影:0.5emrgba(0,0,0,8);
-webkit盒阴影:0.5EMRGBA(0,0,0,8);
盒影:0.5emrgba(0,0,0,8);
}
//JavaScript将出现在这里
美元(初始);
函数init(){
//创建一堆洗牌牌
{
$(#cardPile div')。可拖动({
包含:“#内容”,
堆栈:“#卡片堆div”,
光标:“移动”,
回复:真
} );
}
//创建卡槽
{
$('#cardSlots div')。可拖放({
接受:“#卡片堆div”,
hoverClass:“悬停”,
滴落:手推车滴落
} );
}
函数handleCardDrop(事件,ui){
var slotNumber=$(此值);
var cardname=ui.draggable;
如果(cardNumber==cardNumber){
ui.draggable.addClass('correct');
ui.draggable.draggable('disable');
$(this.dropable('disable');
位置({of:$(this),my:'left top',at:'left top'});
ui.draggable.draggable('option','revert',false);
}
}
}
控制
激励
现实的
有组织的
最像我
第二最像我
第三个最像我的人
最不像我

我修改了你的函数:

function handleCardDrop( event, ui ) {
var slotNumber = $(this);
var cardNumber = ui.draggable;
var choice = cardNumber.html();
var aux = 0;
if (choice == 'Controlling')
{
    aux = 1;
}
if (choice == 'Motivating')
{
    aux = 2;
}
if (choice == 'Realistic')
{
    aux = 3;
}
if (choice == 'Organized')
{
    aux = 4;
}
var droped= slotNumber.html();

if(droped == 'Most Like Me')
{
    $("#uno").val(aux);
}
if(droped == '2nd Most Like Me')
{
    $("#dos").val(aux);
}
if(droped == '3rd Most Like Me')
{
    $("#tres").val(aux);
}
if(droped == 'Least Like Me')
{
    $("#cuatro").val(aux);
}
if ( cardNumber == cardNumber ) {
    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 );
}
}
------------------更新2.0---------------------------

我只是添加了ajax部分,并修改了小提琴:

  $("#saveResult").click(function(){

var uno = $("#uno").val();  
var dos = $("#dos").val();  
var tres = $("#tres").val();  
var cuatro = $("#cuatro").val();
var params = {

            "uno" : uno,

            "dos" : dos,

            "tres" : tres,

            "cuatro": cuatro

    };    
 $.ajax( {
  type: "POST",
  url: 'myphpfile.php',
  data: params,
  success: function( response ) {
    $("#result").html(response);
  }
} );

}); 
在文件myphpfile.php中:

<?php
$uno = $_POST['uno'];
$dos = $_POST['dos'];
$tres = $_POST['tres'];
$cuatro = $_POST['cuatro'];

//Here the code to insert in your database

?>


更新的工作小提琴:

你好,罗伯特,谢谢你的更新。但是表单仍然没有拾取值。我收到一条错误消息,MySQL列被映射到一个不存在的表单元素。如何将上述代码插入MySQL数据库?向我展示您确切的表结构,利用这些信息,我可以制作ajax代码部分来插入数据。表名为DISCflex_Scores。我试图填充的四个字段是F1_1、F1_2、F1_3、F1_4。这四个字段都列为INT。这四个字段与作为值输入的uno to cuatro相关联。嗨,Robert,它正在将表单推送到数据库,但它没有捕获任何值。我在下一篇评论中按照php设置了表。这是我在myphpfile.php上看到的