マップのレイジーローディング

ページにインタラクティブなYandexまたはGoogleマップがある場合、読み込み速度に数秒かかることがあります。GooglePageSpeedレポートを台無しにするのは素晴らしいことです。



この記事では、Yandexマップ接続を最適化する例について説明します。この場合、マウスカーソルを合わせると、遅延してロードされます。



1.まず、Yandexマップ(ここ)を作成して、次のようなスクリプトを取得しましょう。



<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.私たちのサイトでは、カードブロックのコンテナを作成します。



<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>


そして、静止画像のスタイル(スクリーンショットを使用する方が簡単です):



<style>
    .map.container-fluid {
        height: 340px;
        padding: 0;
        background-image: url(/uploads/common/ymap0.png);
        background-position: center center;
    }
</style>


3.最も興味深いのは、マウスのホバーまたは電話のタッチスクリーンのクリックのイベントを追跡するJavaScriptコードを記述し、静止画像をインタラクティブマップに置き換えることです。



<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.利益!あなたのサイトは今、はるかに速くロードされています!



PS:この方法は、JSやCSSを必要としない他のオブジェクトにも適用できます。これにより、ページの読み込み速度が1秒未満になる可能性があります。



All Articles