Как отобразить несколько изображений в один div - PullRequest
0 голосов
/ 16 ноября 2018

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

  foreach($images as $img) {
  echo "<div class=\"container\"><img class=\"photo\" src=\"{$img['file']}\" {$img['size'][3]} alt=\"\">\n</div>";
  }

Ответы [ 4 ]

0 голосов
/ 16 ноября 2018

Не уверен, почему вы все делаете на стороне PHP, но избегайте HTML в PHP как можно больше из-за грязного кодирования.

Я бы:
1. Установите изображения в переменную;
2. Отправьте переменную в шаблон HTML;
3. Зациклите его в шаблоне, где преобладает html;

Если вам абсолютно необходимо сделать HTML в PHP, я бы выбрал подход sprintf;

echo '<div class="container">';
foreach ($images as $img) {
    echo sprintf(
        '<img src="%s" class="img-rounded" alt="%s">',
        $img['file'],
        $img['filename']
    );
}
echo '</div>';

Я считаю, что так понятнее

0 голосов
/ 16 ноября 2018

Вы должны поместить div вне foreach

echo "<div class=\"container\">"; 
foreach($images as $img) {
  echo "<img class=\"photo\" src=\"{$img['file']}\" {$img['size'][3]} alt=\"\">";
 }
echo "</div>";

С вашим реальным кодом вы создаете <div> каждый цикл

0 голосов
/ 16 ноября 2018

Пожалуйста, попробуйте это решение, может быть, оно может помочь вам:

echo "<div class='container'>";
foreach ($images as $img) {
    echo "<img class='photo' src='{$img['file']}' {$img['size'][3]} alt=''>\n</div>";
}
echo "</div>";
0 голосов
/ 16 ноября 2018

Поместите <div> вокруг вашей foreach() петли:

echo '<div class="container">';
foreach($images as $img) {
  echo "<img class=\"photo\" src=\"{$img['file']}\" {$img['size'][3]} alt=\"\">";
  }
echo '</div>';
...