Как установить флажок «Несколько PHP» в соответствии с результатами базы данных? - PullRequest
0 голосов
/ 27 февраля 2019

Я хочу отредактировать информацию о флажке на странице, но когда я нажал на ссылку редактирования, я хочу, чтобы уже выбранный множественный флажок из базы данных был установлен как отмеченный.Но результат, который я получаю из своего кода, состоит в том, что только последний выбранный флажок установлен как отмеченный (отмечен галочкой) вместо всех выбранных флажков.

Вот мой код:

<td><input type = "checkbox" name = "checkbox[]" value = "Badminton" <?php if($interest == 'Badminton') echo "checked = 'checked'"; ?>/>Badminton</td>
<td><input type = "checkbox" name = "checkbox[]" value = "Baseball" <?php if($interest == 'Baseball') echo "checked = 'checked'"; ?>/>Baseball</td>
<td><input type = "checkbox" name = "checkbox[]" value = "Basketball" <?php if($interest == 'Basketball') echo "checked = 'checked'"; ?>/>Basketball</td>
<td><input type = "checkbox" name = "checkbox[]" value = "Cricket" <?php if($interest == 'Cricket') echo "checked = 'checked'"; ?>/>Cricket</td>
<td><input type = "checkbox" name = "checkbox[]" value = "Football" <?php if($interest == 'Football') echo "checked = 'checked'"; ?>/>Football</td>

и вотмой sql код:

$sql = "SELECT * FROM interest where username = '$username'";
$result = $conn->query($sql);
if($result->num_rows > 0)
{
    while($row = $result->fetch_assoc())
    {
        $interest = $row['interest_name'];
    }
}

Ответы [ 2 ]

0 голосов
/ 27 февраля 2019

Прежде всего, если вы хотите использовать все значения из вашего запроса, вам нужно сохранить их в массиве, например:

while($row = $result->fetch_assoc())
{
    $interest[] = $row['interest_name'];
}

Теперь, когда дело доходит до вашего HTML, вы можете перейти как:

<td><input type = "checkbox" name = "checkbox[]" value = "Football" <?php if(in_array('Football',$interest)) echo "checked = 'checked'"; ?>/>Football</td>

Только первый пример, вы должны сделать это во всех из них.

0 голосов
/ 27 февраля 2019

Вы можете сохранить свои значения в массиве, затем вы можете использовать in_array() для проверки:

<?php
$interest = array(); // initializing  
while($row = $result->fetch_assoc())
{
    $interest[] = $row['interest_name']; // store in an array
}
?>

HTML:

<td>
     <input type = "checkbox" name = "checkbox[]" value = "Badminton" <?=(in_array('Badminton',$interest) ? 'checked="checked"' : '')?> />Badminton
</td>

Примечание: Измените другой флажок, как указано выше, с другими имеющимися значениями.

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...