Javascript PHP-处理来自多个输入的数据

Javascript PHP-处理来自多个输入的数据,javascript,php,jquery,sql,Javascript,Php,Jquery,Sql,嘿,伙计们,如果需要的话,我正在使用这个脚本使动态webform添加新的输入 <form method="post" action=""> <table class="dd" width="100%" id="data"> <tr> <td>Vin</td> <td width="99%"><input name="vin1" id="vin1" type="text" /></td&

嘿,伙计们,如果需要的话,我正在使用这个脚本使动态webform添加新的输入

<form method="post" action="">
 <table class="dd" width="100%" id="data">
  <tr>
    <td>Vin</td>
    <td width="99%"><input name="vin1" id="vin1" type="text" /></td>
    </tr>
</table>
<input name="sub" type="submit"  value="Submit values"/>
<input type="button" id="addnew" name="addnew" value="Add new item" /> 
<input type="hidden" id="items" name="items" value="1" />
</form> 
<?php var_dump ($_POST); ?>
<script src="http://code.jquery.com/jquery-latest.js"></script>
<script type='text/javascript'>
//<![CDATA[
 $(document).ready(function() {
  var currentItem = 1;
  $('#addnew').click(function(){
   currentItem++;
   $('#items').val(currentItem);
var strToAdd = '<tr><td>Vin</td><td width="17%"><input name="vin'+currentItem+'" id="vin'+currentItem+'" type="text" /></td></tr>';
   $('#data').append(strToAdd);

  });
 });

//]]>
</script>
它工作得很好,并且还用数字命名每个输入,所以在我的例子中是:vin1,vin2,vin3。。。 问题是我不知道如何告诉PHP处理这些数据。因为我使用的是类似于:

 public function fetchByVinEvidence() {
     $success = false;
     try{
        $con = new PDO( DB_HOST, DB_USER, DB_PASS ); 
        $con->setAttribute( PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION );
        $sql = "SELECT * FROM evidence_calculations WHERE vin = :vin LIMIT 5";
        $stmt = $con->prepare( $sql );
        $stmt->bindValue( "vin", $this->vin, PDO::PARAM_STR );
        $stmt->execute();
            while ($row = $stmt->fetch()){
                echo "<tr>";
                echo "<td>#4</td>";
                echo "<td>".$row['street']."</td>";
                echo "<td>".$row['city']."</td>";
                echo "<td>".$row['claim_number']."</td>";
                echo "<td>".$row['country']."</td>";
                echo "<td><a href =\"javascript:void(0)\" onclick = \"document.getElementById('light').style.display='block';document.getElementById('fade').style.display='block'\">detail</a></td>";
                echo "</tr>";
            }
            }catch(PDOExeption $e){
            echo $e->getMessage();
            echo $con->errorInfo();
            }

         return $success; 
     }
对于单个输入,但如何编辑多个输入,我是PHP OOP新手,因此我真的不确定如何进行适当的循环,如何限制一切,以避免用户立即向数据库发送数以百万计的内容,等等。你们能帮我编辑一下我的PHP脚本,以便能够处理来自多个表单的数据吗


谢谢

提交时,php将自动获取所有具有该名称的输入,并将每个值加载到一个数组中,而不是对输入名称进行编号,只需在vin的末尾追加[]

HTML示例

<input name="vin[]" type="text" />
<input name="vin[]" type="text" />
<input name="vin[]" type="text" />
<input name="vin[]" type="text" />

如果数据库中的每一部分都存在,我如何检查完整数据并为每一部分显示不同的结果呢?@MartinFerko,edited,诸如此类的东西应该可以工作,因为我可以做$vinArray[1],$vinArray[2]但是我不知道用户使用了多少个输入通过使用count:$numInputs=count$vinarrai可以得到数组的长度我在开始上课时使用了类似的东西,你能检查一下你的代码来帮助我工作吗?公共$vin=null;公共函数_构造$data=array{if isset$data['vin']$this->vin=stripslashes strip_标记$data['vin'];}公共函数storeFormValues$params{$this->_构造$params;}
public $vin = array();
public function __construct( $data = array() ) {
     if( isset( $data['vin'] ) ) {
          foreach($data['vin'] as $index=>$vin){
                $this->vin[$index] = stripslashes( strip_tags( $vin ) );     
          }
     }
}
//..
$whereQuery = array();
foreach($this->vin as $index=>$vin){
   $whereQuery[] = "vin= :vin".$index;
}
$sql = "SELECT * FROM evidence_calculations WHERE ".implode(" OR ",$whereQuery)." LIMIT 5";
//...
foreach(array_keys($this->vin) as $index){
   $stmt->bindValue( "vin".$index, $this->vin[$index], PDO::PARAM_STR );
}