Ajax Опубликованные данные не читаются $ _POST в php - PullRequest
0 голосов
/ 03 ноября 2018

Я пытаюсь опубликовать значение полей в таблице через Ajax для process.php, который будет обрабатывать данные.

стол:

<form name="items">
  <table width="90%" border="1">
    <tbody>
      <tr>
        <td width="26%">Item Name</td>
        <td width="22%">If other then give name</td>
        <td width="22%">Quantity</td>
        <td width="16%">$/Unit</td>
        <td width="14%">Total</td>
      </tr>
      <?php for ($i = 1; $i <= 10; $i++) {
    ?>
      <tr>
        <td>
            <select name='itemname<?php echo $i;?>' id='itemname<?php echo $i;?>'>
            <option value="other">other</option>
            <?php
            $qry_item_name = "SELECT DISTINCT item_name FROM bus_name_details";
$result_item_name = mysql_query($qry_item_name);
             while($row_item_name = mysql_fetch_array($result_item_name)) {
            $option .="<option>" . $row_item_name['item_name'] . "</option>";
            echo $option;
        }
            ?>
            </select>
        </td>
        <td>
          <input type="text" name="other<?php echo $i;?>" id="other<?php echo $i;?>"></td>
        <td>
          <input type="text" name="quan<?php echo $i;?>" id="quan<?php echo $i;?>" value="0"></td>
        <td><input type="text" name="unit<?php echo $i;?>" id="unit<?php echo $i;?>" onkeyup="calculateTotal('<?php echo $i;?>')"></td>
        <td><span name="total<?php echo $i;?>" id="total<?php echo $i;?>"></span></td>
      </tr>
      <?php }?>
    </tbody>
  </table>
</form>
<span id="subm3" class="subm3" >Submit </span>

Аякс:

    <script>
$(document).on('click', '.subm3', function() {
            var datas = {};
            for ($i = 1; $i < 2; $i++) {
                // drop down list of items
                datas["item_name"+$i]= $('#itemname'+$i+' option:selected').attr('value')
                // other name 
                datas["other"+$i]= $('input[name=other'+$i+']').val()
                // quantity
                datas["quan"+$i]= $('input[name=quan'+$i+']').val()
                // price per unit 
                datas["unit"+$i]= $('input[name=unit'+$i+']').val()

            }
            $i = $i_limit-1;
                $.ajax({
    url: 'parts/process.php?order=3&items='+$i,
   type: 'POST',
   contentType: 'application/json',
   data: JSON.stringify(datas)

});
        });
</script>

тогда процесс:

<?php 
if ($order==3){

        $loop = $_GET[items];
        $other1= $_POST["other1"];
        echo "other1 = ".$other1;

}
?>

На Chrome Инспектор я получаю, что данные были отправлены в качестве источника: {"item_name1": "other", "other1": "Water Valve", "quan1": "2", "unit1": "2"}

и как это проанализировано: item_name1: «другое» Другое1: «Водяной клапан» quan1: "2" unit1: "2"

но ответ из process.php (тот, который получил значения), похоже, прочитал только значения get, но не значения post: other1 =

Я довольно плохо знаком с AJAX и надеюсь, что кто-то может помочь мне указать, где я здесь ошибаюсь. Возможно, это даже не самый простой и не лучший способ сделать то, что я пытаюсь сделать, но в данный момент это имеет смысл для моего мозга, поэтому я выбираю этот путь. Любая помощь приветствуется

1 Ответ

0 голосов
/ 03 ноября 2018

вы можете попробовать data:datas insted из data: JSON.stringify(datas) в запросе ajax

ref: как отправить несколько данных с помощью $ .ajax () jquery

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...