Уроки

Удаление отложенной загрузки

Отложенная загрузка — это отличная технология. Её задача — ускорить сайт. Это происходит за счёт загрузки изображений по мере того, как они становятся видны пользователю.

Воздержитесь от неё в следующих случаях:

  • При загрузке изображений, расположенных на первом экране. Если изображение видно на первом экране, то лучше загрузить его как можно раньше. Так, страница визуально загрузится быстрее и пользователь раньше начнёт изучать содержимое, даже если загрузка оставшихся файлов находится в процессе.
  • При загрузке мелких изображений. Такие картинки используются как иконки в интерфейсе. Лучше разместить их прямо в CSS или HTML коде в виде base64 строки.

Пример, как включение отложенной загрузки откладывает показ картинок, расположенных на первом экране.

<?php
$mode = $_GET['mode'] ?? '';
?><!DOCTYPE html>
<html>
    <head>
        <meta name="viewport" content="width=device-width, initial-scale=1.0">
        <style>
            .product img {
                max-width:100%;
            }
            .product {
                position: relative;
            }
            .product .time {
                position: absolute;
                left: 5px;
                top: 5px;
                background-color: #fff;
                padding: 1px 4px;
            }
            .btn {
                color: #000;
                display: inline-block;
                margin-bottom: 5px;
                text-decoration: none;
                padding: 5px 10px;
                border: 1px solid #000;
                border-radius: 5px;
            }
            .btn:hover {
                background-color: #ddd;
            }
            .btn.active {
                background-color: #000;
                color: #fff;
            }

        </style>
        <script>
            // Функция, которая добавляет на изображение время окончания загрузки
            function endLoading(el) {
                var time = performance.now()/1000;
                el.parentNode.insertAdjacentHTML("beforeend", '<div class="time">'+time+' с</div>');
            }
        </script>
    </head>
    <body style="font-family: sans-serif;">
        Режим: <a class="btn <?=$mode === '' ? 'active' : ''?>" href="./lazyload_remove.php">Отключённая отложенная загрузка</a> <a class="btn <?=$mode === 'enable' ? 'active' : ''?>" href="./lazyload_remove.php?mode=enable">Включённая отложенная загрузка</a>
        <br />
        <p>Обратите внимание на разницу во времени загрузки изображения.</p>
        <div class="product">
            <img src="./photo.jpg?t=<?=microtime(true)?>" <?=$mode === 'enable' ? 'loading="lazy"' : ''?> onload="endLoading(this)" />
        </div>
        <?php for($i = 0; $i < 100;++$i) { ?>
        <script src="./10-kb-js.js?t=<?=microtime(true).'.'.$i?>"/></script>
        <?php } ?>
    </body>
</html>
<!DOCTYPE html>
<html>
    <head>
        <meta name="viewport" content="width=device-width, initial-scale=1.0">
        <style>
            .product img {
                max-width:100%;
            }
            .product {
                position: relative;
            }
            .product .time {
                position: absolute;
                left: 5px;
                top: 5px;
                background-color: #fff;
                padding: 1px 4px;
            }
            .btn {
                color: #000;
                display: inline-block;
                margin-bottom: 5px;
                text-decoration: none;
                padding: 5px 10px;
                border: 1px solid #000;
                border-radius: 5px;
            }
            .btn:hover {
                background-color: #ddd;
            }
            .btn.active {
                background-color: #000;
                color: #fff;
            }

        </style>
        <script>
            // Функция, которая добавляет на изображение время окончания загрузки
            function endLoading(el) {
                var time = performance.now()/1000;
                el.parentNode.insertAdjacentHTML("beforeend", '<div class="time">'+time+' с</div>');
            }
        </script>
    </head>
    <body style="font-family: sans-serif;">
        Режим: <a class="btn active" href="./lazyload_remove.php">Отключённая отложенная загрузка</a> <a class="btn " href="./lazyload_remove.php?mode=enable">Включённая отложенная загрузка</a>
        <br />
        <p>Обратите внимание на разницу во времени загрузки изображения.</p>
        <div class="product">
            <img src="./photo.jpg?t=1780708411.8655"  onload="endLoading(this)" />
        </div>
                <script src="./10-kb-js.js?t=1780708411.8655.0"/></script>
                <script src="./10-kb-js.js?t=1780708411.8655.1"/></script>
                <script src="./10-kb-js.js?t=1780708411.8655.2"/></script>
                <script src="./10-kb-js.js?t=1780708411.8655.3"/></script>
                <script src="./10-kb-js.js?t=1780708411.8655.4"/></script>
                <script src="./10-kb-js.js?t=1780708411.8655.5"/></script>
                <script src="./10-kb-js.js?t=1780708411.8655.6"/></script>
                <script src="./10-kb-js.js?t=1780708411.8655.7"/></script>
                <script src="./10-kb-js.js?t=1780708411.8655.8"/></script>
                <script src="./10-kb-js.js?t=1780708411.8655.9"/></script>
                <script src="./10-kb-js.js?t=1780708411.8655.10"/></script>
                <script src="./10-kb-js.js?t=1780708411.8655.11"/></script>
                <script src="./10-kb-js.js?t=1780708411.8655.12"/></script>
                <script src="./10-kb-js.js?t=1780708411.8655.13"/></script>
                <script src="./10-kb-js.js?t=1780708411.8655.14"/></script>
                <script src="./10-kb-js.js?t=1780708411.8655.15"/></script>
                <script src="./10-kb-js.js?t=1780708411.8655.16"/></script>
                <script src="./10-kb-js.js?t=1780708411.8655.17"/></script>
                <script src="./10-kb-js.js?t=1780708411.8655.18"/></script>
                <script src="./10-kb-js.js?t=1780708411.8655.19"/></script>
                <script src="./10-kb-js.js?t=1780708411.8655.20"/></script>
                <script src="./10-kb-js.js?t=1780708411.8655.21"/></script>
                <script src="./10-kb-js.js?t=1780708411.8655.22"/></script>
                <script src="./10-kb-js.js?t=1780708411.8655.23"/></script>
                <script src="./10-kb-js.js?t=1780708411.8655.24"/></script>
                <script src="./10-kb-js.js?t=1780708411.8655.25"/></script>
                <script src="./10-kb-js.js?t=1780708411.8655.26"/></script>
                <script src="./10-kb-js.js?t=1780708411.8655.27"/></script>
                <script src="./10-kb-js.js?t=1780708411.8655.28"/></script>
                <script src="./10-kb-js.js?t=1780708411.8655.29"/></script>
                <script src="./10-kb-js.js?t=1780708411.8655.30"/></script>
                <script src="./10-kb-js.js?t=1780708411.8655.31"/></script>
                <script src="./10-kb-js.js?t=1780708411.8655.32"/></script>
                <script src="./10-kb-js.js?t=1780708411.8655.33"/></script>
                <script src="./10-kb-js.js?t=1780708411.8655.34"/></script>
                <script src="./10-kb-js.js?t=1780708411.8655.35"/></script>
                <script src="./10-kb-js.js?t=1780708411.8655.36"/></script>
                <script src="./10-kb-js.js?t=1780708411.8655.37"/></script>
                <script src="./10-kb-js.js?t=1780708411.8655.38"/></script>
                <script src="./10-kb-js.js?t=1780708411.8655.39"/></script>
                <script src="./10-kb-js.js?t=1780708411.8655.40"/></script>
                <script src="./10-kb-js.js?t=1780708411.8655.41"/></script>
                <script src="./10-kb-js.js?t=1780708411.8655.42"/></script>
                <script src="./10-kb-js.js?t=1780708411.8655.43"/></script>
                <script src="./10-kb-js.js?t=1780708411.8655.44"/></script>
                <script src="./10-kb-js.js?t=1780708411.8655.45"/></script>
                <script src="./10-kb-js.js?t=1780708411.8655.46"/></script>
                <script src="./10-kb-js.js?t=1780708411.8655.47"/></script>
                <script src="./10-kb-js.js?t=1780708411.8655.48"/></script>
                <script src="./10-kb-js.js?t=1780708411.8655.49"/></script>
                <script src="./10-kb-js.js?t=1780708411.8655.50"/></script>
                <script src="./10-kb-js.js?t=1780708411.8655.51"/></script>
                <script src="./10-kb-js.js?t=1780708411.8655.52"/></script>
                <script src="./10-kb-js.js?t=1780708411.8655.53"/></script>
                <script src="./10-kb-js.js?t=1780708411.8655.54"/></script>
                <script src="./10-kb-js.js?t=1780708411.8655.55"/></script>
                <script src="./10-kb-js.js?t=1780708411.8655.56"/></script>
                <script src="./10-kb-js.js?t=1780708411.8655.57"/></script>
                <script src="./10-kb-js.js?t=1780708411.8655.58"/></script>
                <script src="./10-kb-js.js?t=1780708411.8655.59"/></script>
                <script src="./10-kb-js.js?t=1780708411.8655.60"/></script>
                <script src="./10-kb-js.js?t=1780708411.8655.61"/></script>
                <script src="./10-kb-js.js?t=1780708411.8655.62"/></script>
                <script src="./10-kb-js.js?t=1780708411.8655.63"/></script>
                <script src="./10-kb-js.js?t=1780708411.8655.64"/></script>
                <script src="./10-kb-js.js?t=1780708411.8655.65"/></script>
                <script src="./10-kb-js.js?t=1780708411.8655.66"/></script>
                <script src="./10-kb-js.js?t=1780708411.8655.67"/></script>
                <script src="./10-kb-js.js?t=1780708411.8655.68"/></script>
                <script src="./10-kb-js.js?t=1780708411.8655.69"/></script>
                <script src="./10-kb-js.js?t=1780708411.8655.70"/></script>
                <script src="./10-kb-js.js?t=1780708411.8655.71"/></script>
                <script src="./10-kb-js.js?t=1780708411.8655.72"/></script>
                <script src="./10-kb-js.js?t=1780708411.8655.73"/></script>
                <script src="./10-kb-js.js?t=1780708411.8655.74"/></script>
                <script src="./10-kb-js.js?t=1780708411.8655.75"/></script>
                <script src="./10-kb-js.js?t=1780708411.8655.76"/></script>
                <script src="./10-kb-js.js?t=1780708411.8655.77"/></script>
                <script src="./10-kb-js.js?t=1780708411.8655.78"/></script>
                <script src="./10-kb-js.js?t=1780708411.8655.79"/></script>
                <script src="./10-kb-js.js?t=1780708411.8655.80"/></script>
                <script src="./10-kb-js.js?t=1780708411.8655.81"/></script>
                <script src="./10-kb-js.js?t=1780708411.8655.82"/></script>
                <script src="./10-kb-js.js?t=1780708411.8655.83"/></script>
                <script src="./10-kb-js.js?t=1780708411.8655.84"/></script>
                <script src="./10-kb-js.js?t=1780708411.8655.85"/></script>
                <script src="./10-kb-js.js?t=1780708411.8655.86"/></script>
                <script src="./10-kb-js.js?t=1780708411.8655.87"/></script>
                <script src="./10-kb-js.js?t=1780708411.8655.88"/></script>
                <script src="./10-kb-js.js?t=1780708411.8655.89"/></script>
                <script src="./10-kb-js.js?t=1780708411.8655.90"/></script>
                <script src="./10-kb-js.js?t=1780708411.8655.91"/></script>
                <script src="./10-kb-js.js?t=1780708411.8655.92"/></script>
                <script src="./10-kb-js.js?t=1780708411.8655.93"/></script>
                <script src="./10-kb-js.js?t=1780708411.8655.94"/></script>
                <script src="./10-kb-js.js?t=1780708411.8655.95"/></script>
                <script src="./10-kb-js.js?t=1780708411.8655.96"/></script>
                <script src="./10-kb-js.js?t=1780708411.8655.97"/></script>
                <script src="./10-kb-js.js?t=1780708411.8655.98"/></script>
                <script src="./10-kb-js.js?t=1780708411.8655.99"/></script>
            </body>
</html>

Тарифные планы для работы с сервисом

Мы используем cookie. Продолжая пользоваться сайтом, вы соглашаетесь на обработку персональных данных в соответствии с политикой конфиденциальности. Соглашаюсь