Bootstrap 4 Collapse открывают и закрывают все элементы вместе - PullRequest
0 голосов
/ 04 ноября 2019

У меня есть динамическая страница, где Bootstrap Collapse показывает данные из базы данных. Здесь, если я нажимаю на любую ссылку, все элементы коллапса открываются все вместе и закрываются вообще. Затем я попытался создать уникальный идентификатор, используя цикл while, но после этого коллапс не работает.

<?php                    
   $i=0;
   while ($row = mysqli_fetch_assoc($notice)) {                     
?>

<div class="panel-group" id="accordion6" role="tablist" aria-multiselectable="true">
    <div class="panel panel-default">
        <div class="panel-heading" role="tab" id="headingOne6">
            <h4 class="panel-title">
                <a role="button" data-toggle="collapse" data-parent="#accordion6" href="#<?php echo $i; ?>" aria-expanded="true" aria-controls="collapseOne6">
                    <?php echo $row['title']; ?>
                </a>
            </h4>
        </div>
        <div id="<?php echo $i; ?>" class="panel-collapse collapse" role="tabpanel" aria-labelledby="headingOne6">
            <div class="panel-body">
                <?php echo $row['description']; ?>
            </div>
        </div>
    </div>
</div>

<?PHP 
    $i++;
}?>

1 Ответ

0 голосов
/ 04 ноября 2019

Ваш код генерирует дублирующийся идентификатор headingOne6. Я изменил ваш код для создания уникального идентификатора.

<?php

   $i=0;
   while ($row = mysqli_fetch_assoc($notice)) {

?>

 <div class="panel-group" id="<?php echo 'accordion'.$i; ?>" role="tablist" aria-multiselectable="true">
    <div class="panel panel-default">
        <div class="panel-heading" role="tab" id="<?php echo 'headingOne'.$i; ?>">
            <h4 class="panel-title">
                <a role="button" data-toggle="collapse" data-parent="<?php echo '#accordion'.$i; ?>" href="#<?php echo $i; ?>" aria-expanded="true" aria-controls="<?php echo 'collapseOne'.$i; ?>">
                    <?php echo $row['title']; ?>
                </a>
            </h4>
        </div>
        <div id="<?php echo $i; ?>" class="panel-collapse collapse" role="tabpanel" aria-labelledby="<?php echo 'headingOne'.$i; ?>">
            <div class="panel-body">
                <?php echo $row['description']; ?>
            </div>
        </div>
    </div>

</div>
<?PHP 
    $i++;
}?>
...