我有一个简单的ajax(jQuery版本)脚本和一个非常短的php函数,它们工作正常而没有问题。当我从表单输入are中提交值时,ajax会发送并从php脚本中获取结果,在这种情况下,该ajax可以获取预定的总金额。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> </p> </form>
以下用作xml的php脚本也可以与上述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 =“ result ”或“ result1”)。
您应该id使用class 替换属性,因为id在dom中应该是唯一的,并且使用class可以循环执行以获取购物车中所有物品的数量
id
我注意到的另一件事是,您为购物车中的每个商品都制作了一个单独的表单,应该有一个包含多个字段的表单,也请删除此行<input type="submit" name="qty",这样做确实有意义
<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>