Уроки

Последовательность подключения JavaScript файлов

Страница состоит из десятков файлов. Они загружаются в той последовательности в которой перечислены в HTML коде страницы. JavaScript отвечает за интерактивную часть страницы, а CSS и картинки за визуальную.

Чем раньше пользователь увидит графические элементы и контент, чем раньше он приступит к его изучению, тем выше будет конверсия страницы. Чтобы JavaScript файлы не откладывали показ графики страницы, перенесите подключение JavaScript файлов в конце страницы, после CSS файлов и картинок.

Ниже пример разницы между подключением JavaScript в начале и в конце страницы.

<?php
$mode = $_GET['mode'] ?? 'start';

$jsHtml = '';
for($i = 0; $i < 100;++$i) {
    $jsHtml .= '<script src="./10-kb-js.js?t='.microtime(true).'.'.$i.'"/></script>'."\n";
}

?><!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>
        <?php
        if($mode === 'start')
            echo $jsHtml;
        ?>
    </head>
    <body style="font-family: sans-serif;">
        Режим: <a class="btn <?=$mode === 'start' ? 'active' : ''?>" href="./js_not_at_end.php">Подключение JavaScript в head</a> <a class="btn <?=$mode === 'end' ? 'active' : ''?>" href="./js_not_at_end.php?mode=end">Подключение JavaScript в конце страницы</a>
        <br />
        <p>Обратите внимание на разницу во времени загрузки изображения.</p>
        <div class="product">
            <img src="./photo.jpg?t=<?=microtime(true)?>" onload="endLoading(this)" />
        </div>
    </body>
    <?php
    if($mode === 'end')
        echo $jsHtml;
    ?>
</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>
        <script src="./10-kb-js.js?t=1776510607.0672.0"/></script>
<script src="./10-kb-js.js?t=1776510607.0672.1"/></script>
<script src="./10-kb-js.js?t=1776510607.0672.2"/></script>
<script src="./10-kb-js.js?t=1776510607.0672.3"/></script>
<script src="./10-kb-js.js?t=1776510607.0672.4"/></script>
<script src="./10-kb-js.js?t=1776510607.0672.5"/></script>
<script src="./10-kb-js.js?t=1776510607.0672.6"/></script>
<script src="./10-kb-js.js?t=1776510607.0672.7"/></script>
<script src="./10-kb-js.js?t=1776510607.0672.8"/></script>
<script src="./10-kb-js.js?t=1776510607.0672.9"/></script>
<script src="./10-kb-js.js?t=1776510607.0672.10"/></script>
<script src="./10-kb-js.js?t=1776510607.0672.11"/></script>
<script src="./10-kb-js.js?t=1776510607.0672.12"/></script>
<script src="./10-kb-js.js?t=1776510607.0672.13"/></script>
<script src="./10-kb-js.js?t=1776510607.0672.14"/></script>
<script src="./10-kb-js.js?t=1776510607.0672.15"/></script>
<script src="./10-kb-js.js?t=1776510607.0672.16"/></script>
<script src="./10-kb-js.js?t=1776510607.0672.17"/></script>
<script src="./10-kb-js.js?t=1776510607.0672.18"/></script>
<script src="./10-kb-js.js?t=1776510607.0672.19"/></script>
<script src="./10-kb-js.js?t=1776510607.0672.20"/></script>
<script src="./10-kb-js.js?t=1776510607.0672.21"/></script>
<script src="./10-kb-js.js?t=1776510607.0672.22"/></script>
<script src="./10-kb-js.js?t=1776510607.0672.23"/></script>
<script src="./10-kb-js.js?t=1776510607.0672.24"/></script>
<script src="./10-kb-js.js?t=1776510607.0672.25"/></script>
<script src="./10-kb-js.js?t=1776510607.0672.26"/></script>
<script src="./10-kb-js.js?t=1776510607.0672.27"/></script>
<script src="./10-kb-js.js?t=1776510607.0672.28"/></script>
<script src="./10-kb-js.js?t=1776510607.0672.29"/></script>
<script src="./10-kb-js.js?t=1776510607.0672.30"/></script>
<script src="./10-kb-js.js?t=1776510607.0672.31"/></script>
<script src="./10-kb-js.js?t=1776510607.0672.32"/></script>
<script src="./10-kb-js.js?t=1776510607.0672.33"/></script>
<script src="./10-kb-js.js?t=1776510607.0672.34"/></script>
<script src="./10-kb-js.js?t=1776510607.0672.35"/></script>
<script src="./10-kb-js.js?t=1776510607.0672.36"/></script>
<script src="./10-kb-js.js?t=1776510607.0672.37"/></script>
<script src="./10-kb-js.js?t=1776510607.0672.38"/></script>
<script src="./10-kb-js.js?t=1776510607.0672.39"/></script>
<script src="./10-kb-js.js?t=1776510607.0672.40"/></script>
<script src="./10-kb-js.js?t=1776510607.0672.41"/></script>
<script src="./10-kb-js.js?t=1776510607.0672.42"/></script>
<script src="./10-kb-js.js?t=1776510607.0672.43"/></script>
<script src="./10-kb-js.js?t=1776510607.0672.44"/></script>
<script src="./10-kb-js.js?t=1776510607.0672.45"/></script>
<script src="./10-kb-js.js?t=1776510607.0672.46"/></script>
<script src="./10-kb-js.js?t=1776510607.0672.47"/></script>
<script src="./10-kb-js.js?t=1776510607.0672.48"/></script>
<script src="./10-kb-js.js?t=1776510607.0672.49"/></script>
<script src="./10-kb-js.js?t=1776510607.0672.50"/></script>
<script src="./10-kb-js.js?t=1776510607.0672.51"/></script>
<script src="./10-kb-js.js?t=1776510607.0672.52"/></script>
<script src="./10-kb-js.js?t=1776510607.0672.53"/></script>
<script src="./10-kb-js.js?t=1776510607.0672.54"/></script>
<script src="./10-kb-js.js?t=1776510607.0672.55"/></script>
<script src="./10-kb-js.js?t=1776510607.0672.56"/></script>
<script src="./10-kb-js.js?t=1776510607.0672.57"/></script>
<script src="./10-kb-js.js?t=1776510607.0672.58"/></script>
<script src="./10-kb-js.js?t=1776510607.0672.59"/></script>
<script src="./10-kb-js.js?t=1776510607.0672.60"/></script>
<script src="./10-kb-js.js?t=1776510607.0672.61"/></script>
<script src="./10-kb-js.js?t=1776510607.0672.62"/></script>
<script src="./10-kb-js.js?t=1776510607.0672.63"/></script>
<script src="./10-kb-js.js?t=1776510607.0672.64"/></script>
<script src="./10-kb-js.js?t=1776510607.0672.65"/></script>
<script src="./10-kb-js.js?t=1776510607.0672.66"/></script>
<script src="./10-kb-js.js?t=1776510607.0672.67"/></script>
<script src="./10-kb-js.js?t=1776510607.0672.68"/></script>
<script src="./10-kb-js.js?t=1776510607.0672.69"/></script>
<script src="./10-kb-js.js?t=1776510607.0672.70"/></script>
<script src="./10-kb-js.js?t=1776510607.0672.71"/></script>
<script src="./10-kb-js.js?t=1776510607.0672.72"/></script>
<script src="./10-kb-js.js?t=1776510607.0672.73"/></script>
<script src="./10-kb-js.js?t=1776510607.0672.74"/></script>
<script src="./10-kb-js.js?t=1776510607.0673.75"/></script>
<script src="./10-kb-js.js?t=1776510607.0673.76"/></script>
<script src="./10-kb-js.js?t=1776510607.0673.77"/></script>
<script src="./10-kb-js.js?t=1776510607.0673.78"/></script>
<script src="./10-kb-js.js?t=1776510607.0673.79"/></script>
<script src="./10-kb-js.js?t=1776510607.0673.80"/></script>
<script src="./10-kb-js.js?t=1776510607.0673.81"/></script>
<script src="./10-kb-js.js?t=1776510607.0673.82"/></script>
<script src="./10-kb-js.js?t=1776510607.0673.83"/></script>
<script src="./10-kb-js.js?t=1776510607.0673.84"/></script>
<script src="./10-kb-js.js?t=1776510607.0673.85"/></script>
<script src="./10-kb-js.js?t=1776510607.0673.86"/></script>
<script src="./10-kb-js.js?t=1776510607.0673.87"/></script>
<script src="./10-kb-js.js?t=1776510607.0673.88"/></script>
<script src="./10-kb-js.js?t=1776510607.0673.89"/></script>
<script src="./10-kb-js.js?t=1776510607.0673.90"/></script>
<script src="./10-kb-js.js?t=1776510607.0673.91"/></script>
<script src="./10-kb-js.js?t=1776510607.0673.92"/></script>
<script src="./10-kb-js.js?t=1776510607.0673.93"/></script>
<script src="./10-kb-js.js?t=1776510607.0673.94"/></script>
<script src="./10-kb-js.js?t=1776510607.0673.95"/></script>
<script src="./10-kb-js.js?t=1776510607.0673.96"/></script>
<script src="./10-kb-js.js?t=1776510607.0673.97"/></script>
<script src="./10-kb-js.js?t=1776510607.0673.98"/></script>
<script src="./10-kb-js.js?t=1776510607.0673.99"/></script>
    </head>
    <body style="font-family: sans-serif;">
        Режим: <a class="btn active" href="./js_not_at_end.php">Подключение JavaScript в head</a> <a class="btn " href="./js_not_at_end.php?mode=end">Подключение JavaScript в конце страницы</a>
        <br />
        <p>Обратите внимание на разницу во времени загрузки изображения.</p>
        <div class="product">
            <img src="./photo.jpg?t=1776510607.0673" onload="endLoading(this)" />
        </div>
    </body>
    </html>

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

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