php - 从 PHP foreach 循环获取 Ajax 变量

标签 php javascript jquery ajax

我有一个简单的ajax(jquery版本)脚本和非常短的php函数,它们工作正常,没有问题。 当我提交表单输入中的值时,ajax将发送并获取结果 php 脚本,在本例中获取图书订单的总金额。 Ajax脚本和html部分如下:

     <script language="JavaScript">
   $(document).ready(function() {
   $("form").mouseout( function() {
      // get field value

      var qtyVal = $('#qty').val();
      // use HTTP GET get ajax 
        $.ajax({
        type: 'GET',
        url:  'getSunBody.php',
        data: { qty : qtyVal,
                 }, 
        success: function(data) {
           //get xml value
                    $('#result').html($(data).find('qty').text()); 
           $('#result1').html($(data).find('caution').text());   

        } 
      });    
      return false;
   });
});
</script>


<body>
Total price:<div id="result" class="box" style="height=350px;"></div><div id="result1" class="box" style="height=350px;"></div>
<form>
  <p>
    <label>quantity: </label>
    <input type="text" id="qty" name="qty"/> 
    <br/>
       <input type="submit" value="submit">
    total price:</p>
  <p>&nbsp;</p>
</form>

下面的 php 脚本作为 xml 也可以很好地处理上面的 ajax 请求:

<?php
// XML document
header("Content-Type: text/xml");
header("Content-Type:text/html; charset=utf-8");
// get field values
$qty = (isset($_POST["qty"]) ) ? $_POST["qty"] : $_GET["qty"];

echo "<?xml version=\"1.0\" ?>";

echo "<datetime>"; 
echo "<qty>" . $qty*100 . "</qty>";

$total=$qty*100;
if ($total==0)
    echo "<caution>"."please input number!"."</caution>";
    else if ($total<=500)
    echo "<caution>"."you shoud buy more!"."</caution>";
    echo "";

echo "</datetime>";

?>

但是,当我将上述脚本与购物车 foreach 循环结合使用时,它不起作用,并且 ajax 脚本无法从表单输入区域获取变量。我不知道这是否是变量范围问题(全局或局部)?或者其他什么?

以下是我想要修复的总脚本:

<script language="JavaScript">
$(document).ready(function() {
   $("form").mouseout( function() {
      // get value from the form

      var qtyVal = $('#qty').val();
      // get 
        $.ajax({
        type: 'GET',
        url:  'getSunBody.php',
        data: { qty : qtyVal,
                 }, 
        success: function(data) {
           // get XML value
           $('#result').html($(data).find('qty').text()); 
           $('#result1').html($(data).find('caution').text());   

        } 
      });    
      return false;
   });
});
</script>
</head>

<body>
<table border="1" align="center">
<tr>
  <th>no</th>
  <th>name</th>
  <th>price</th>
  <th>qty</th>
  <th>update</th>
</tr>
<?php
foreach( $_SESSION["psn"] as $i => $data ){
?>
<form action="sessionCartUpdate.php">
<input type="hidden" name="psn" value="<?php echo $_SESSION["psn"][$i];?>">
<tr>
  <td><?php echo $_SESSION["psn"][$i];?></td>
  <td><?php echo $_SESSION["pname"][$i];?></td>
  <td><?php echo $_SESSION["price"][$i];?></td>
  <td><input type="text" id="qty" name="qty" value="<?php echo $_SESSION["qty"][$i];?>"></td>
  <input type="submit" name="qty" 
  <td><input type="submit" name="btnUpdate" value="update" />
      <input type="submit" name="btnDelete" value="delete" />
      </td>
</tr>
</form>
<?php
}
?>
<tr><td colsan="5">total amount:<div id="result" class="box" style="height=350px;"></div><div id="result1" class="box" style="height=350px;"></div></td></td>
</table>
<p><a href="sessionProdList.php">continue to shop</a>
<p><a href="sessionCartToDb.php">Put your order</a>
</body>
</html>

如果有人能提供善意或可能的建议或建议,我将不胜感激? 我的目标是通过使用ajax将不同的数字(变量)放入“输入区域”(名称或id为“数量”)来获取总价格并在div框中显示结果(id =“结果” ”或“结果1”)。

最佳答案

您应该替换 id带有 class 的属性,因为 id 在 dom 中应该是唯一的,并且使用 class 您可以执行循环来获取购物车中商品的所有数量

我注意到的另一件事是,您为购物车中的每个商品制作了单独的表单,应该有一个表单具有多个字段,同时删除此行 <input type="submit" name="qty"这没有道理

<form action="sessionCartUpdate.php">
<?php
foreach( $_SESSION["psn"] as $i => $data ){
?>

<input type="hidden" name="psn" value="<?php echo $_SESSION["psn"][$i];?>">
<tr>
  <td><?php echo $_SESSION["psn"][$i];?></td>
  <td><?php echo $_SESSION["pname"][$i];?></td>
  <td><?php echo $_SESSION["price"][$i];?></td>
  <td><input type="text" class="qty" name="qty[]" value="<?php echo $_SESSION["qty"][$i];?>"></td>

  <td><input type="submit" name="btnUpdate" value="update" />
      <input type="submit" name="btnDelete" value="delete" />
      </td>
</tr>

<?php
}
?>
</form>

<script language="JavaScript">
$(document).ready(function() {
   $("form").mouseout( function() {
var qtyVal =0;
$( ".qty" ).each(function() {
  qtyVal =qtyVal + parseInt($(this).val()); 
});      
      // get 
        $.ajax({
        type: 'GET',
        url:  'getSunBody.php',
        data: { qty : qtyVal,
                 }, 
        success: function(data) {
           // get XML value
           $('#result').html($(data).find('qty').text()); 
           $('#result1').html($(data).find('caution').text());   

        } 
      });    
      return false;
   });
});
</script> 

关于php - 从 PHP foreach 循环获取 Ajax 变量,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/18145838/

相关文章:

javascript:克隆对象及其节点

php - 使用 OROPlatform 时如何测试我自己的代码?

javascript - 添加查看源代码按钮

php - 网站将 php 文件下载到浏览器而不是运行它

javascript - HapiJS——以最大内存运行服务器

JavaScript 代码不打印消息

jquery - 如何设置页脚响应?

javascript - Angular.js 和 JavaScript 管理

php - 更改密码代码错误

php - Mysql 使用 Like 运算符在 json 数组中搜索