Das Arbeiten mit iFrames in modernen Webseiten bietet eine einfache Möglichkeit, externe Inhalte wie Kalender, Buchungssysteme oder andere Dienste nahtlos einzubinden. In diesem Artikel erfahren Sie, wie Sie die Höhe eines iFrames dynamisch anpassen können, sodass der Inhalt auf allen Geräten korrekt angezeigt wird.
Das Beispiel ist für den Microsoft Kalender
Schritt 1: Erstellen Sie ein benutzerdefiniertes Child-Theme
Bevor Sie Änderungen vornehmen, sollten Sie ein Child-Theme erstellen, um sicherzustellen, dass Ihre Anpassungen bei zukünftigen Theme-Updates erhalten bleiben. Ein Child-Theme kann durch die Erstellung eines neuen Ordners im Verzeichnis wp-content/themes/
sowie durch eine style.css
und eine functions.php
erstellt werden.
Schritt 2: Einbetten des iFrames in Ihre Webseite
Der erste Schritt besteht darin, das iFrame in Ihre Seite einzufügen. Verwenden Sie dafür folgenden HTML-Code:
<iframe id="bookingIframe" src="https://outlook.office365.com/owa/calendar/Example@outlook.com/bookings/" width="100%" scrolling="no" style="border:0"></iframe>
Dieser Code bettet das iFrame nahtlos in Ihre Webseite ein und sorgt dafür, dass es die volle Breite des Containers einnimmt.
Schritt 3: JavaScript für die dynamische Höhenanpassung hinzufügen
Um sicherzustellen, dass die Höhe des iFrames dynamisch angepasst wird, müssen wir JavaScript verwenden. Der folgende Code prüft den Inhalt des iFrames und passt die Höhe entsprechend an:
<script>
function resizeIframe() {
var iframe = document.getElementById('bookingIframe');
try {
var iframeDocument = iframe.contentWindow.document;
var contentHeight = iframeDocument.body.scrollHeight;
iframe.style.height = contentHeight + 'px';
} catch (e) {
console.error('Kann die Größe des Inhalts nicht ermitteln:', e);
}
}
window.addEventListener('load', function() {
var iframe = document.getElementById('bookingIframe');
iframe.onload = function() {
resizeIframe();
};
setInterval(resizeIframe, 1000);
});
window.addEventListener('resize', resizeIframe);
</script>
Dieser JavaScript-Code überprüft regelmäßig die Höhe des Inhalts des iFrames und passt die iFrame-Höhe entsprechend an. So bleibt der gesamte Inhalt, einschließlich Buttons, sichtbar.
Schritt 4: Mobile und Tablet-Optimierung
Da iFrames oft auf mobilen Geräten Probleme bereiten, wurde der Code so erweitert, dass er verschiedene Pufferwerte für unterschiedliche Bildschirmgrößen verwendet. Dies gewährleistet eine optimale Darstellung auf Smartphones und Tablets:
<script>
function resizeIframe() {
var iframe = document.getElementById('bookingIframe');
try {
var iframeDocument = iframe.contentWindow.document;
var contentHeight = iframeDocument.body.scrollHeight;
if (window.innerWidth < 480) {
iframe.style.height = (contentHeight + 200) + 'px';
} else if (window.innerWidth < 768) {
iframe.style.height = (contentHeight + 150) + 'px';
} else {
iframe.style.height = contentHeight + 'px';
}
} catch (e) {
console.error('Kann die Größe des Inhalts nicht ermitteln:', e);
}
}
window.addEventListener('load', function() {
var iframe = document.getElementById('bookingIframe');
iframe.onload = function() {
resizeIframe();
};
setInterval(resizeIframe, 1000);
});
window.addEventListener('resize', resizeIframe);
</script>
Hier stellen wir sicher, dass auf mobilen Geräten zusätzliche Puffer zur Höhe hinzugefügt werden, um Inhalte und Buttons im iFrame anzuzeigen.
Schritt 5: Testen der Lösung
Testen Sie die Änderungen gründlich auf verschiedenen Geräten und Bildschirmgrößen, um sicherzustellen, dass der gesamte Inhalt des iFrames, einschließlich der Buttons, sichtbar ist. Falls der Inhalt sich dynamisch ändert, können Sie den Intervallwert im setInterval()
bei Bedarf anpassen.
Schlussfolgerung
Mit diesen einfachen Schritten haben Sie erfolgreich die Höhe eines iFrames dynamisch angepasst und dafür gesorgt, dass der gesamte Inhalt korrekt angezeigt wird. Diese Technik ist besonders hilfreich, wenn Sie externe Dienste wie Buchungssysteme oder Kalender in Ihre Webseite einbinden. Durch die dynamische Anpassung verbessern Sie die Benutzerfreundlichkeit und vermeiden unerwünschte Scrollbalken.