php7-mysql-data/Kapitel_3/Lektion_9/fotogalerie_loesung/index.php

106 lines
2.3 KiB
PHP
Raw Normal View History

2016-08-16 21:20:53 +02:00
<?php
$fotos = [
[
'dateiname' => '1.jpg',
'tags' => 'Industrie'
],
[
'dateiname' => '2.jpg',
'tags' => 'Gebäude'
],
[
'dateiname' => '3.jpg',
'tags' => 'Gebäude, Natur'
],
[
'dateiname' => '4.jpg',
'tags' => 'Industrie'
],
[
'dateiname' => '5.jpg',
'tags' => 'Natur'
],
[
'dateiname' => '6.jpg',
'tags' => 'Gebäude, Natur'
],
[
'dateiname' => '7.jpg',
'tags' => 'Natur'
],
[
'dateiname' => '8.jpg',
'tags' => 'Gebäude'
],
[
'dateiname' => '9.jpg',
'tags' => 'Industrie'
]
];
function filter($liste, $suchbegriff)
{
$ergebnis = [];
foreach ($liste as $listenEintrag) {
if (false !== stripos($listenEintrag['tags'], $suchbegriff)) {
$ergebnis[] = $listenEintrag;
}
}
return $ergebnis;
}
if (count($_POST) > 0) {
$suchbegriff = $_POST['suchbegriff'];
$fotosGefiltert = filter($fotos, $suchbegriff);
} else {
$suchbegriff = '';
$fotosGefiltert = $fotos;
}
?>
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>Fotogalerie</title>
<style>
.miniatur {
float: left;
}
.miniatur img {
margin-right: 10px;
}
.clearfix {
clear: both;
}
</style>
</head>
<body>
<h1>Fotogalerie</h1>
<p><?= count($fotosGefiltert); ?> von <?= count($fotos); ?> Fotos</p>
<?php foreach ($fotosGefiltert as $foto) : ?>
<div>
<div class="miniatur" style="float: left;">
<a href="foto.php?dateiname=<?= htmlspecialchars($foto['dateiname']); ?>">
<img src="miniaturen/<?= htmlspecialchars($foto['dateiname']); ?>" alt="<?= htmlspecialchars($foto['dateiname']); ?>">
</a>
</div>
Dateiname: <?= htmlspecialchars($foto['dateiname']); ?><br>
Tags: <?= htmlspecialchars($foto['tags']); ?>
<div class="clearfix"></div>
</div>
<?php endforeach; ?>
<div>
<form action="index.php" method="post">
<label for="suchbegriff">Suchbegriff:</label>
<input type="text" id="suchbegriff" name="suchbegriff" value="<?= htmlspecialchars($suchbegriff); ?>"/>
<button type="submit">Anwenden</button>
</form>
</div>
</body>
</html>