【发布时间】:2014-04-11 20:08:39
【问题描述】:
试图检查用户在表单上输入的数量是否大于库存。如果是,那么它应该在表单上将数量设置为 STOCK VALUE。
if (isset($_SESSION["cart_array"]))
{
if (isset($_POST['item_to_adjust']) && $_POST['item_to_adjust'] != "") {
// execute some code
$item_to_adjust = $_POST['item_to_adjust'];
$quantity = $_POST['quantity'];
$quantity = preg_replace('#[^0-9]#i', '', $quantity); // filter everything but numbers
if ($quantity >= 100) { $quantity = 99; }
if ($quantity < 1) { $quantity = 1; }
if ($quantity == "") { $quantity = 1; }
$sqlquan = mysql_query("SELECT * FROM products WHERE id='$item_id' LIMIT 1");
while ($row = mysql_fetch_array($sqlquan)) {
$item_id= $row["id"];
$stock= $row["stock"];
}
if ($quantity > $stock)
{echo "much";
$quantity=$stock;}
$i = 0;
foreach ($_SESSION["cart_array"] as $each_item) {
$i++;
while (list($key, $value) = each($each_item)) {
if ($key == "item_id" && $value == $item_to_adjust) {
// That item is in cart already so let's adjust its quantity using array_splice()
array_splice($_SESSION["cart_array"], $i-1, 1, array(array("item_id" => $item_to_adjust, "quantity" => $quantity)));
} // close if condition
} // close while loop
} // close foreach loop
}
}
问题是我的购物车中有 2 件商品。第一个的库存值为 15,第二个的库存值为 23。如果我为第一个产品输入的数量大于 15,则效果很好(将数量设置为 15)。但是,如果我为第二个产品输入一个大于 15 但小于 23 的值,它会与第一个产品的库存值进行比较并再次重置为 15。
【问题讨论】:
-
您的问题是什么?此代码如何未按预期执行?有任何错误消息吗?
-
问题是我在购物车中有 2 件商品。第一个的库存值为 15,第二个的库存值为 23。如果我为第一个产品输入的数量大于 15,则效果很好(将数量设置为 15)。但是如果我为第二个产品输入一个大于 15 但小于 23 的值,它会与第一个产品的库存值进行比较并再次重置为 15。
-
@user3525190
$_POST['quantity']似乎没有绑定到任何项目,所以您首先需要制作一个与所有项目对应的数量数组。 -
对不起,我无法显示整个代码。很多行。
-
您可以随时编辑原始问题以添加大量新代码或新信息。如果您有小代码 sn-ps,您可以使用反引号
like this将它们作为代码显示在注释中。