In diesem Artikel werde ich ein Beispiel für die Optimierung einer Yandex-Kartenverbindung beschreiben, bei der sie beim Bewegen des Mauszeigers verzögert geladen wird.
1. Zuerst erstellen wir eine Yandex-Karte ( hier ) und erhalten ein Skript, ungefähr so:
<script type="text/javascript"
charset="utf-8"
async
src="https://api-maps.yandex.ru/services/constructor/1.0/js/?um=constructor%3A1ad4887964fc2e0a6f07c6246ffe638b138f8baacc8983f9a6a0f401a02e833a&width=1280&height=400&lang=ru_RU&scroll=true"></script>
2. Auf unserer Website schreiben wir einen Container für den Kartenblock:
<div id="map_container" class="map container-fluid">
<script id="ymap_lazy"
async
data-src="https://api-maps.yandex.ru/services/constructor/1.0/js/?um=constructor%3A1ad4887964fc2e0a6f07c6246ffe638b138f8baacc8983f9a6a0f401a02e833a&width=1280&height=400&lang=ru_RU&scroll=true"></script>
</div>
Und die Stile für unser statisches Bild (es ist einfacher, es mit Screenshots zu erstellen):
<style>
.map.container-fluid {
height: 340px;
padding: 0;
background-image: url(/uploads/common/ymap0.png);
background-position: center center;
}
</style>
3. Am interessantesten ist es, JavaScript-Code zu schreiben, der Ereignisse beim Bewegen der Maus oder beim Klicken auf den Touchscreen des Telefons verfolgt und das statische Bild durch eine interaktive Karte ersetzt:
<script>
let map_container = document.getElementById('map_container');
let options_map = {
once: true,// ,
passive: true,
capture: true
};
map_container.addEventListener('click', start_lazy_map, options_map);
map_container.addEventListener('mouseover', start_lazy_map, options_map);
map_container.addEventListener('touchstart', start_lazy_map, options_map);
map_container.addEventListener('touchmove', start_lazy_map, options_map);
let map_loaded = false;
function start_lazy_map() {
if (!map_loaded) {
let map_block = document.getElementById('ymap_lazy');
map_loaded = true;
map_block.setAttribute('src', map_block.getAttribute('data-src'));
map_block.removeAttribute('data_src');
console.log('YMAP LOADED');
}
}
</script>
4. Profitieren Sie! Ihre Website wird jetzt viel schneller geladen!
PS: Diese Methode kann auch für andere Objekte angepasst werden, für die JS und CSS nicht erforderlich sind. Aufgrund dessen kann die Seitenladegeschwindigkeit weniger als eine Sekunde betragen.