微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

如何在php中使用foreach和条件回显带有onclick功能的按钮?

如何解决如何在php中使用foreach和条件回显带有onclick功能的按钮?

期待:

从我的 sql 中选择数据。 Foreach 回显数据和按钮。 当数据为空时,显示具有 onclick 功能的“加入”按钮。 当数据“加入”时,隐藏具有onclick功能的“加入”按钮,显示具有onclick功能的“结果”按钮。

结果:

使用onclick功能无法隐藏“join”按钮,使用onclick功能显示“result”按钮。

<!DOCTYPE html>
<html>
<head>
</head>
<body>
<?PHP
    
         $servername = "localhost";
         $username = "root";
         $password = "";
         $dbname = "battle";
        try {
            $conn = new PDO("MysqL:host=$servername;dbname=$dbname",$username,$password);
            $conn->setAttribute(PDO::ATTR_ERRMODE,PDO::ERRMODE_EXCEPTION);
            $stmt = $conn->prepare("SELECT * FROM battleRecord Group by id");
            $stmt->execute();
            $stmt->setFetchMode(PDO::FETCH_ASSOC);
                                        
            foreach ($stmt->fetchAll() as $row) {
              if ($row['participation'] == 'joined') {
                $displayJoin = 'none';
                $displayResult = 'block';
            } else {
                $displayJoin = 'block';
                $displayResult = 'none';
            }
               ?>

              <tr>
              <td style='width:150px;border:1px solid black;'>                                
              <p><?PHP echo $row['id']?></p>
            
              </td>  
              <td style='width:150px;border:1px solid black;'>                                
              <button style="display:<?PHP echo $displayJoin ?>" id="joinBattle" onclick="joinBattle(<?PHP echo htmlspecialchars($row['id']) ?>)">joinbattle</button>
              
              <button style="display:<?PHP echo $displayResult ?>" id="checkResult" onclick="checkResult(<?PHP echo htmlspecialchars($row['result']) ?>)">result</button>
              
              </td>  
              </tr>
                                                
              <?PHP

                }
                } catch (PDOException $e) {
                  echo "Error: " . $e->getMessage();
                }
                  $conn = null;
                  
                   ?>

   
    </body>
    </html>

结果和MysqL

MySQL part 1

MySQL part 2

Result

View Source

解决方法

您从未将 $displayJoin 设置为 block。使用这个:

if ($row['participation'] == 'joined') {
    $displayJoin = 'none';
    $displayResult = 'block';
} else {
    $displayJoin = 'block';
    $displayResult = 'none';
}

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。