简体   繁体   English

如何使用Ajax和PHP从动态文本框中插入数据?

[英]How to insert data from a dynamic textbox using Ajax and PHP?

I have a dynamic textbox inside my bootstrap modal but it only saves the first item. 我的引导程序模版中有一个动态文本框,但它仅保存第一项。 However, I have tried using the native submit without using Ajax and it captures all data inputted. 但是,我尝试使用本机提交而不使用Ajax,它捕获所有输入的数据。 I can't figure out where I have gone wrong on my Ajax code. 我无法弄清楚我的Ajax代码出了什么问题。 I just want to insert all data inputted from dynamic textbox without reloading the page. 我只想插入从动态文本框输入的所有数据,而无需重新加载页面。 Here's my sample code: 这是我的示例代码:

 <!-- start dynamic fields for parameter -->
    <div class="row">
        <div class="col-md-12">
          <div class="input-group control-group after-add-more">
          <?php require 'lab/pardrop.php'; ?> <!--dropdown list for parnam-->
          </select>
         <input type="text" name="parval[]" class="form-control" id="parval" 
               placeholder="Value" >
         <button class="btn btn-success addmore" type="button" data- 
               toggle="tooltip" title="Add Parameter">
            <i class="glyphicon glyphicon-plus"></i></button>
        </div>
        </div>
    </div>
<!--start hidden fields-->  
     <div class="row">
        <div class="col-md-12">
          <div class="copy-fields hide">
            <div class="control-group input-group">
             <?php require 'lab/pardrop.php'; ?> <!--dropdown list for parnam-->
              </select>
              <input type="text" name="parval[]" id="parval" class="form- 
                 control" placeholder="Value" >
                <button class="btn btn-danger remove" type="button">
                  <i class="glyphicon glyphicon-remove"></i></button>
            </div>
        </div>
        </div>
    </div> 
<div class="modal-footer">
     <button class="btn btn-info" type="button" name="btnsamp2" 
      id="btnsamp2"> 
</button>
 </div>  

<!--Ajax code-->

<script>
    $(document).ready(function(){

        $("#btnsamp2").click(function(){
          var parnam=$("#parnam").val();
          var parval=$("#parval").val();

          $.ajax({
                url:'insamp2.php', 
                method:'POST',
                data:{
                      parnam:parnam,
                      parval:parval
                    },
                   success:function(data){
                       alert(data);
                   }
                });
            });
        });
</script>

<!--PHP Code-->

<?php
  //insamp2.php
  require 'lab/db/dbcon.php';
  $num = count($_POST["parnam"]) OR ($_POST["bacnam"]);
  $parnam=mysqli_escape_string($con, $_POST['parnam']);
  $parval=mysqli_escape_string($con, $_POST['parval']);


  if($num > 0){  
      for($i=0; $i<$num; $i++)  
      {  
           if($_POST["parnam"][$i] != '' && $_POST["parval"][$i] )  
           {  

            $sql = "INSERT INTO pardtls(parnam,parval) VALUES ('".$parnam[$i]."','".$parval[$i]."')";
              mysqli_query($con, $sql);

           }  
      } 
          echo "Parameter inserted";  
     }  
     else  
     {  
          echo "Failed inserting data";  
     } 

?>

The code below serializes all relevant input arrays so their values can be passed to the php handler. 下面的代码对所有相关的输入数组进行序列化,因此它们的值可以传递给php处理程序。

You can use this jquery code: 您可以使用以下jQuery代码:

<script>
    $(document).ready(function(){

        $("button[name='btnsamp2']").click(function(){
          $.ajax({
                url:'insamp2.php', 
                method:'POST',
                data: $('input[name="parval[]"]').serialize() + '&' + $('input[name="parnam[]"]').serialize(),
                   success:function(data){
                       alert(data);
                   }
                });
            });
        });
</script>

Alternatively , you can enclose your input tags in <form> tag. 或者 ,您可以将input tags<form>标签中。

Then use this jquery code: 然后使用以下jQuery代码:

<script>
    $(document).ready(function(){
        $("button[name='btnsamp2']").click(function(){
          $.ajax({
                url:'insamp2.php', 
                method:'POST',
                data: $('form').serialize() + '&submit=1',
                   success:function(data){
                       alert(data);
                   }
                });
            });
        });
</script>

In your PHP script there are some errors. 您的PHP脚本中存在一些错误。 You were counting the elements of incoming $_POST variables the bad way. 您正在用不好的方式计算传入的$_POST变量的元素。

$num = count($_POST["parnam"]) OR ($_POST["bacnam"]); // bad counting.. fixed it in the code below.

And you were doing mysqli_real_escape_string(..) on $_POST array values which would cause an error and would also render the values needed empty. 并且您在$_POST数组值上执行mysqli_real_escape_string(..) ,这将导致错误,并使所需的值mysqli_real_escape_string(..)空。

Also in the below code added proper insert alerts. 同样在下面的代码中添加了正确的插入警报。

Try this updated PHP code . 试试这个更新的PHP代码

<?php
  require 'lab/db/dbcon.php';
  $num = isset($_POST['parnam'])?count($_POST['parnam']):0;
  $contid=mysqli_escape_string($con, $_POST['contid']);
  $sampno=mysqli_escape_string($con, $_POST['sampno']);
  $statno=mysqli_escape_string($con, $_POST['statno']);
  $statname=mysqli_escape_string($con, $_POST['statname']);
  $coltime=mysqli_escape_string($con, $_POST['coltime']); 
  $parnam=isset($_POST['parnam'])?$_POST['parnam']:array();
  $parval=isset($_POST['parval'])?$_POST['parval']:array();
  $bacnam=isset($_POST['bacnam'])?$_POST['bacnam']:array();
  $bacval=isset($_POST['bacval'])?$_POST['bacval']:array();

  $sql="INSERT INTO samp (contid,sampno,statno,statname,coltime) VALUES ('$contid', '$sampno','$statno','$statname','$coltime')";
  if ($con->query($sql) === TRUE && $sampno!="" && $statno!="" ) {
      echo "Success! Data inserted";
  }
  else 
  {
      echo "Failed! Please input data!";
  }

  if($num > 0){  
      for($i=0; $i<$num; $i++)  
      {  
           if($_POST['sampno'] && $_POST["parnam"][$i] != '' && $_POST["parval"][$i] != '' && $_POST["bacnam"][$i] != '' && $_POST["bacval"][$i] != '')  
           { 
              $parnam[$i]=mysqli_escape_string($con, $parnam[$i]);
              $parval[$i]=mysqli_escape_string($con, $parval[$i]);
              $bacnam[$i]=mysqli_escape_string($con, $bacnam[$i]);
              $bacval[$i]=mysqli_escape_string($con, $bacval[$i]);

            $sql = "INSERT INTO pardtls(sampno,parnam,parval,bacnam,bacval) VALUES ('".$sampno."','".$parnam[$i]."','".$parval[$i]."','".$bacnam[$i]."','".$bacval[$i]."')";
            $inserted = mysqli_query($con, $sql);
            if($inserted === false){
                echo "A record not inserted at index $i ..<br/>\n";
                echo mysqli_error($con)."<br/>\n";
            }

           }  
      } 
     }  
     else  
     {  
          echo "Failed! Please input data";
     } 
?>

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM