1

请原谅我,因为我不精通 php/mysql。我有一个用于库存的 html 表单。我有一组字段来更新我的 sql 数据库,它们是 item_name、item_cost、item_quantity。我有一个 jquery 按钮,允许用户动态添加其他项目/行。

问题:我怎样才能让 php 循环用户添加的任何数量的项目并将它们放入 mysql 数据库中?

感谢您的时间。

4

2 回答 2

4

如果您有多个具有相同名称的表单输入,并且该名称以双方括号结尾,则当 PHP从表单中[]填充时,它们的值将转换为一个数组。$_POST

因此,您的 jQuery 按钮应该插入一行,其中包含如下命名的字段:

<input type="text" name="item_name[]" value="" />
<input type="text" name="item_cost[]" value="" />
<input type="text" name="item_quantity[]" value="" />

在接受表单提交的 PHP 代码中,您可以像这样处理所有存在的行:

//I used `item_name` as the loop termination condition, 
//but any of the 3 keys would have worked
for ($i = 0; $i < count($_POST['item_name']); $i++) {
    $item_name = $_POST['item_name'][$i];
    $item_cost = $_POST['item_cost'][$i];
    $item_quantity = $_POST['item_quantity'][$i];

    //here, inside the loop, run your database query using the 3 values above    
}
于 2012-08-21T22:07:48.007 回答
0

另一种(硬)方法是有一个隐藏的输入框,它的值是用户想要提交的项目的数量,在每个 jquery“添加按钮”点击时,隐藏输入的值也将被更新(值++),并且您应该在使用 jquery 制作它们时执行其他输入名称,例如“name_id”,这样您就可以在服务器端获取它们......

于 2012-08-21T22:14:02.730 回答