在PHP生成的表中添加和访问按钮ID

时间:2016-04-27 09:17:49

标签: javascript php html mysql

我的php有问题,它生成一个表,从SQL数据库请求数据,并将数据存储在表中。

表中每行的第一个单元格包含一个下拉按钮,该按钮链接到删除该行的delete.php脚本。它还链接到用于修改行的单元格的modif.php脚本。 我的问题是,我需要访问带有ID的下拉按钮,以了解要删除的行。

我真的不知道如何将我的下拉按钮与ID相关联,并在我的脚本中访问它们。

以下是代码:

<?php
  $con=mysqli_connect("localhost","root","icare","icare1");
  // Check connection
  if (mysqli_connect_errno())
  {
  echo "Failed to connect to MySQL: " . mysqli_connect_error();
  }

  $result = mysqli_query($con,"SELECT * FROM magasin");

  echo "<table border='1'>
  <tr>
  <th>code</th>
  <th>ip</th>
  <th>ads</th>
  <th>region</th>
  <th>adress</th>
  <th>name</th>
  <th>email</th>
  <th>number</th>
  <th>gtc</th>
  <th>date</th>
  </tr>";

  $indexB = array();
  $i = 0;
  while($row = mysqli_fetch_array($result))
  {
    echo "<tr>";
    echo "<td>
          <div class='dropdown'>
            <button id=$indexB[$i] class='dropbtn'>▶</button>
            <div class='dropdown-content'>
              <a href='modif.php'>Modifier</a>
              <a href='delete.php'>Supprimer</a>
            </div>
            ".$row['code']."
          </div>
    </td>";

    echo "<td><div>" . $row['ip'] . "</div></td>";
    echo "<td><div>" . $row['ads'] . "</div></td>";
    echo "<td><div>" . $row['region'] . "</div></td>";
    echo "<td><div>" . $row['adress'] . "</div></td>";
    echo "<td><div>" . $row['name'] . "</div></td>";
    echo "<td><div>" . $row['email'] . "</div></td>";
    echo "<td><div>" . $row['number'] . "</div></td>";
    echo "<td><div>" . $row['gtc'] . "</div></td>";
    echo "<td><div>" . $row['date'] . "</td>";
    echo "</tr>";
    $i++;
  }
    echo "</table>";
    mysqli_close($con);
?>

这是delete.php:

<?php
  $connection = mysqli_connect("localhost", "root", "icare", "icare1");
  if($connection === false){
      die("Connection failed " . mysqli_connect_error());
  };


    //$id =
    $sql = "DELETE FROM magasin WHERE Code=".$id;

    //$result = mysqli_query($connection,$sql);

    if(mysqli_query($connection, $sql)){
        echo "Done !";
    } else{
      echo "Failed : $sql. " . mysqli_error($connection);
    }
  mysqli_close($connection);
?>

我启动了一个indexB []来存储下拉列表ID,但我不确定我做得对。 最后,我想将我的按钮链接到代码属性,然后使用代码属性删除带有我的SQL查询的行。

我是新手,所以...对不起,如果我做了或者问了一些简单的愚蠢。

更新: 致mikrafizik:

我尝试了你的答案,但它不起作用。我只得到“1”&gt; Supprimer“。它似乎有href的问题,但我只是找不到原因。 我不知道我忘了什么,所以如果你看错了:

<?php
  $con=mysqli_connect("localhost","root","icare","icare1");
  // Check connection
  if (mysqli_connect_errno())
  {
  echo "Failed to connect to MySQL: " . mysqli_connect_error();
  }

  $result = mysqli_query($con,"SELECT * FROM magasin");

  echo "<table border='1'>
  <tr>
  <th>Code</th>
  <th>Adresse IP</th>
  <th>Adresse ADS</th>
  <th>Région</th>
  <th>Adresse</th>
  <th>Nom du directeur</th>
  <th>Mail</th>
  <th>Téléphone</th>
  <th>GTC</th>
  <th>Date d'installation</th>
  </tr>";

$data = mysqli_fetch_array($result);
?>

    <table>
<?php foreach ($data as $key => $row):?>
<tr>
 <td>
    <div class='dropdown-content'>
      <button class='dropbtn'>▶</button>
          <!-- <a href="modif.php?id=<?=$row['id']?>">Modifier</a> -->
          <a href="delete.php?id=<?php echo $row['id']?>">Supprimer</a>
    </div>
 </td>
 <td><div><?php echo $row['AdresseIP'];?></div></td>
 <td><div><?php echo $row['AdresseADS'];?></div></td>
 <td><div><?php echo $row['Region'];?></div></td>
 <td><div><?php echo $row['Adresse'];?></div></td>
 <td><div><?php echo $row['NomDirecteur'];?></div></td>
 <td><div><?php echo $row['Mail'];?></div></td>
 <td><div><?php echo $row['Tel'];?></div></td>
 <td><div><?php echo $row['Gtc'];?></div></td>
 <td><div><?php echo $row['DateInstall'];?></td>
</tr>
<?php endforeach; ?>
</table>

<?mysqli_close($con);?>

delete.php:

<?php
  $connection = mysqli_connect("localhost", "root", "icare", "icare1");
  if($connection === false){
      die("Connexion échouée " . mysqli_connect_error());
  };

    $id = $_GET['id'];
    $sql = "DELETE FROM magasin WHERE Code=".$id;

    $result = mysqli_query($connection,$sql);

    if($result){
        echo "Enregistrement réussi !";
    } else{
      echo "Enregistrement échoué : $sql. " . mysqli_error($connection);
    }
  mysqli_close($connection);
?>

2 个答案:

答案 0 :(得分:1)

首先,将查询和表单构建划分为

$data = mysqli_fetch_array($result)

然后

<?php foreach ($data as $key => $row): ?>
<tr>
 <td>
    <div class='dropdown-content'>
          <a href='modif.php?id=<?=$row['id']?>'>Modifier</a>
          <a href='delete.php?id=<?=$row['id']?>'>Supprimer</a>
    </div>
 </td>
</tr>
<?php endforeach ?>

在你的modif.php中

$id = $_GET['id'];

答案 1 :(得分:0)

(关注Flumble_的回答,由于我的低代表,我无法发表评论)

可能<?= ?>是问题所在。尝试使用<?php ?>

替换它们

更新:

您也不应该使用空置标记(<? ?>):请参阅the answer to this question

此外,当您编写<?php $row['id'] ?>时,您不会打印该值。你必须写<?php echo $row['id']; ?>。 同样的事情适用于短开标签(但不适用于<?=语法)。

希望这有助于进一步发展。我将继续审核您的代码。

更新2:

好吧,我想我明白了。 mysqli_fetch_array会返回,而不是整个结果集。所以你必须循环遍历行,直到mysqli_fetch_array返回NULL:

while($data = mysqli_fetch_array($result)) {

    ?>
    <tr>
        <!-- ... -->
    </tr>
    <?php
}