0

我正在尝试获取 mysql 行的 $w['id'] 值,并使用隐藏的输入字段和变量 $blog_id 将其传递到另一个页面。这是第一页的代码:

$query = "SELECT * FROM blog WHERE username = '$username' ORDER BY created_date DESC;";
$result = $mysqli->query($query);
$rows = resultToArray($result);
// var_dump($rows); 
foreach($rows as $r => $w) {
echo "<tr>\n";
    echo "<td>{$w['title']}\n";
    echo "<td>{$w['id']}\n";
echo "<td>{$w['created_date']}</td>\n";
echo "<td>{$w['updated_date']}</td>\n";
echo "<td style=\"border:none\">{$w['template']}</td>\n";

$blog_id = $w['id'];

echo "<input type=\"hidden\" name=\"id\" value=\"$blog_id\" />\n";
echo "<td style=\"border:none\"><button type=\"submit\" name=\"view\">View</button></td>\n";

echo "<td style=\"border:none\"><button type=\"submit\" name=\"edit\">Edit</button></td>\n";

echo "<td style=\"border:none\"><button type=\"submit\" name=\"delete\"><font color=\"red\">Delete</font></button></td>";
echo "</tr>\n";
}

?>

在我的 html 表中,值正确回显,但是当我尝试获取 $w['id'] 值并使用例如编辑按钮将其传递到下一页时,该值始终是 mysql 表中的最低 id 值。
第二页关键部分的代码是:

sec_session_start();
$username = $_SESSION['username'];
// $blog_id = $_SESSION['blog_id'];

if(isset ($_POST['edit'])) {
    $blog_id = $_POST['id'];

    $result = $mysqli->query("SELECT * FROM blog WHERE id = '$blog_id'");

    if($result->num_rows > 0) { 
        $rows = resultToArray($result);
        foreach($rows as $r => $w) { 

        ?>

        <body id="blog_editor">
<?php var_dump($_POST); ?>

var_dump($_POST) 的值始终是 ["id"]=>string(2) "43" 而第一页上的 foreach 循环会产生许多不同的 ID。有谁知道我做错了什么,或者有另一种方法可以做同样的事情?

4

1 回答 1

0

您使用 aforeach和 echo 许多不同的id.

我没有看到任何SUBMIT按钮或<form>标签。

您可以做的是,在 foreach 循环中,使用 is own 按钮创建一个表单:

<?php
    foreach($rows as $r => $w) {
       echo '<form action="page.php" ...>
       echo ....
       echo '<input type="submit">
    }
?>

name或者,如果您在一个表单中有多个结果,那么每次循环循环时,您都必须更改元素的

为此,请更改此行:

echo "<input type=\"hidden\" name=\"id\" value=\"$blog_id\" />\n";

1)对此:

echo "<input type='hidden' name='id".$blog_id."' value='$blog_id' />\n";

然后当你打电话时,$_POST你会有$_POST['idXX']哪里 XX = ID 号码

2) 或 TO this 创建一个包含所有 ID 的数组:

echo "<input type='hidden' name='id[]' value='$blog_id' />\n";

然后$_POST['id']将是一个数组

于 2013-06-10T02:04:33.643 回答