Lessons

Grouping JavaScript files

To download a file, the browser spends time on service operations: establishing a connection, sending a request, receiving a response, closing a connection. This time is constant and does not depend on the speed of the Internet connection. For example, with a very fast Internet connection, it will take 1 millisecond to download the contents of the file, and up to 100 for service operations. The execution time of service operations depends on the network latency — ping, and not on the speed of the Internet connection.

To speed up the site, programmers group many small JavaScript files into one large one. There are plug-ins that automatically connect files.

For one page, it is acceptable to use no more than 3 JavaScript files.

Why enabling grouping can break a site

The reason may be a change in the order in which JavaScript files are connected. For example, your script depends on jQuery. But after enabling grouping, the order of the files has changed, and in the final merged file, your script goes first, and only then the jQuery library code. This situation can be easily identified, as errors appear in the browser console.

Why are not all files grouped

The most common reason is to connect JavaScript files via HTML code, instead of using the API method of your site management system.

Use the following code: language-html <script src="/js/my_script.js"></script> instead of this: “language-php // For Bitrix Asset::getInstance()->addJs(SITE_TEMPLATE_PATH . “/js/my_script.js”); // For WordPress wp_enqueue_script( ‘my-script-handle’, get_template_directory_uri() . ‘/js/my_script.js’, array(‘tmp’), ‘1.0’, true ); “` Each system has several ways to connect JavaScript code. You need to use the one that suits the situation.

Below is an example of how grouping speeds up page loading:

Demonstration
PHP code
HTML code
<?php
if(isset($_GET['big'])) {
    // Выводим сгруппированный, большой файл
    header('Content-Type: text/js');
    for($i = 0;$i < 100;$i++)
    echo file_get_contents('10-kb-js.js');
    die;
}
$mode = $_GET['mode'] ?? '';
?><!DOCTYPE html>
<html>
    <head>
        <meta name="viewport" content="width=device-width, initial-scale=1.0">
        <style>
            .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>
            window.addEventListener("load", (event) => {
                document.querySelector('#page-load').innerHTML = 'Страница загрузилась (событие window.onload) за <b>'+(performance.now()/1000)+'с</b>.';
            });
        </script>
    </head>
    <body style="font-family: sans-serif;">
        Режим: <a class="btn <?=$mode === '' ? 'active' : ''?>" href="./js_count.php">100 файлов по 10 КБ</a> <a class="btn <?=$mode === 'big' ? 'active' : ''?>" href="./js_count.php?mode=big">1 файл размером 1 МБ</a>
        <br />
        <p id="page-load">Тут отобразится время загрузки страницы (вызова события window.onload)</p>
<?php
if($mode === 'big') {?>
        <script src="./js_count.php?big=1"></script>
<?php
} else {
    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>
            .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>
            window.addEventListener("load", (event) => {
                document.querySelector('#page-load').innerHTML = 'Страница загрузилась (событие window.onload) за <b>'+(performance.now()/1000)+'с</b>.';
            });
        </script>
    </head>
    <body style="font-family: sans-serif;">
        Режим: <a class="btn active" href="./js_count.php">100 файлов по 10 КБ</a> <a class="btn " href="./js_count.php?mode=big">1 файл размером 1 МБ</a>
        <br />
        <p id="page-load">Тут отобразится время загрузки страницы (вызова события window.onload)</p>
        <script src="./10-kb-js.js?t=1772846831.689.0"/></script>
            <script src="./10-kb-js.js?t=1772846831.689.1"/></script>
            <script src="./10-kb-js.js?t=1772846831.689.2"/></script>
            <script src="./10-kb-js.js?t=1772846831.689.3"/></script>
            <script src="./10-kb-js.js?t=1772846831.689.4"/></script>
            <script src="./10-kb-js.js?t=1772846831.689.5"/></script>
            <script src="./10-kb-js.js?t=1772846831.689.6"/></script>
            <script src="./10-kb-js.js?t=1772846831.689.7"/></script>
            <script src="./10-kb-js.js?t=1772846831.689.8"/></script>
            <script src="./10-kb-js.js?t=1772846831.689.9"/></script>
            <script src="./10-kb-js.js?t=1772846831.689.10"/></script>
            <script src="./10-kb-js.js?t=1772846831.689.11"/></script>
            <script src="./10-kb-js.js?t=1772846831.689.12"/></script>
            <script src="./10-kb-js.js?t=1772846831.689.13"/></script>
            <script src="./10-kb-js.js?t=1772846831.689.14"/></script>
            <script src="./10-kb-js.js?t=1772846831.689.15"/></script>
            <script src="./10-kb-js.js?t=1772846831.689.16"/></script>
            <script src="./10-kb-js.js?t=1772846831.689.17"/></script>
            <script src="./10-kb-js.js?t=1772846831.689.18"/></script>
            <script src="./10-kb-js.js?t=1772846831.689.19"/></script>
            <script src="./10-kb-js.js?t=1772846831.689.20"/></script>
            <script src="./10-kb-js.js?t=1772846831.689.21"/></script>
            <script src="./10-kb-js.js?t=1772846831.689.22"/></script>
            <script src="./10-kb-js.js?t=1772846831.689.23"/></script>
            <script src="./10-kb-js.js?t=1772846831.689.24"/></script>
            <script src="./10-kb-js.js?t=1772846831.689.25"/></script>
            <script src="./10-kb-js.js?t=1772846831.689.26"/></script>
            <script src="./10-kb-js.js?t=1772846831.689.27"/></script>
            <script src="./10-kb-js.js?t=1772846831.689.28"/></script>
            <script src="./10-kb-js.js?t=1772846831.689.29"/></script>
            <script src="./10-kb-js.js?t=1772846831.689.30"/></script>
            <script src="./10-kb-js.js?t=1772846831.689.31"/></script>
            <script src="./10-kb-js.js?t=1772846831.689.32"/></script>
            <script src="./10-kb-js.js?t=1772846831.689.33"/></script>
            <script src="./10-kb-js.js?t=1772846831.689.34"/></script>
            <script src="./10-kb-js.js?t=1772846831.689.35"/></script>
            <script src="./10-kb-js.js?t=1772846831.689.36"/></script>
            <script src="./10-kb-js.js?t=1772846831.689.37"/></script>
            <script src="./10-kb-js.js?t=1772846831.689.38"/></script>
            <script src="./10-kb-js.js?t=1772846831.689.39"/></script>
            <script src="./10-kb-js.js?t=1772846831.689.40"/></script>
            <script src="./10-kb-js.js?t=1772846831.689.41"/></script>
            <script src="./10-kb-js.js?t=1772846831.689.42"/></script>
            <script src="./10-kb-js.js?t=1772846831.689.43"/></script>
            <script src="./10-kb-js.js?t=1772846831.689.44"/></script>
            <script src="./10-kb-js.js?t=1772846831.689.45"/></script>
            <script src="./10-kb-js.js?t=1772846831.689.46"/></script>
            <script src="./10-kb-js.js?t=1772846831.689.47"/></script>
            <script src="./10-kb-js.js?t=1772846831.689.48"/></script>
            <script src="./10-kb-js.js?t=1772846831.689.49"/></script>
            <script src="./10-kb-js.js?t=1772846831.689.50"/></script>
            <script src="./10-kb-js.js?t=1772846831.689.51"/></script>
            <script src="./10-kb-js.js?t=1772846831.689.52"/></script>
            <script src="./10-kb-js.js?t=1772846831.689.53"/></script>
            <script src="./10-kb-js.js?t=1772846831.689.54"/></script>
            <script src="./10-kb-js.js?t=1772846831.689.55"/></script>
            <script src="./10-kb-js.js?t=1772846831.689.56"/></script>
            <script src="./10-kb-js.js?t=1772846831.689.57"/></script>
            <script src="./10-kb-js.js?t=1772846831.689.58"/></script>
            <script src="./10-kb-js.js?t=1772846831.689.59"/></script>
            <script src="./10-kb-js.js?t=1772846831.689.60"/></script>
            <script src="./10-kb-js.js?t=1772846831.689.61"/></script>
            <script src="./10-kb-js.js?t=1772846831.689.62"/></script>
            <script src="./10-kb-js.js?t=1772846831.689.63"/></script>
            <script src="./10-kb-js.js?t=1772846831.689.64"/></script>
            <script src="./10-kb-js.js?t=1772846831.689.65"/></script>
            <script src="./10-kb-js.js?t=1772846831.689.66"/></script>
            <script src="./10-kb-js.js?t=1772846831.689.67"/></script>
            <script src="./10-kb-js.js?t=1772846831.689.68"/></script>
            <script src="./10-kb-js.js?t=1772846831.689.69"/></script>
            <script src="./10-kb-js.js?t=1772846831.689.70"/></script>
            <script src="./10-kb-js.js?t=1772846831.689.71"/></script>
            <script src="./10-kb-js.js?t=1772846831.689.72"/></script>
            <script src="./10-kb-js.js?t=1772846831.689.73"/></script>
            <script src="./10-kb-js.js?t=1772846831.689.74"/></script>
            <script src="./10-kb-js.js?t=1772846831.689.75"/></script>
            <script src="./10-kb-js.js?t=1772846831.689.76"/></script>
            <script src="./10-kb-js.js?t=1772846831.689.77"/></script>
            <script src="./10-kb-js.js?t=1772846831.689.78"/></script>
            <script src="./10-kb-js.js?t=1772846831.689.79"/></script>
            <script src="./10-kb-js.js?t=1772846831.689.80"/></script>
            <script src="./10-kb-js.js?t=1772846831.689.81"/></script>
            <script src="./10-kb-js.js?t=1772846831.689.82"/></script>
            <script src="./10-kb-js.js?t=1772846831.689.83"/></script>
            <script src="./10-kb-js.js?t=1772846831.689.84"/></script>
            <script src="./10-kb-js.js?t=1772846831.689.85"/></script>
            <script src="./10-kb-js.js?t=1772846831.689.86"/></script>
            <script src="./10-kb-js.js?t=1772846831.689.87"/></script>
            <script src="./10-kb-js.js?t=1772846831.689.88"/></script>
            <script src="./10-kb-js.js?t=1772846831.689.89"/></script>
            <script src="./10-kb-js.js?t=1772846831.689.90"/></script>
            <script src="./10-kb-js.js?t=1772846831.689.91"/></script>
            <script src="./10-kb-js.js?t=1772846831.689.92"/></script>
            <script src="./10-kb-js.js?t=1772846831.6891.93"/></script>
            <script src="./10-kb-js.js?t=1772846831.6891.94"/></script>
            <script src="./10-kb-js.js?t=1772846831.6891.95"/></script>
            <script src="./10-kb-js.js?t=1772846831.6891.96"/></script>
            <script src="./10-kb-js.js?t=1772846831.6891.97"/></script>
            <script src="./10-kb-js.js?t=1772846831.6891.98"/></script>
            <script src="./10-kb-js.js?t=1772846831.6891.99"/></script>
        </body>
</html>

PRO subscription for working with the service

Promo
Checking 50 pages in the tool "Checking the page"
190 ₽
The subscription is activated for 10 days and is linked to a specific site.
PRO subscription
3,500 pages per week in tools "Checking the page" and "Full site scan".
1 580 ₽
The subscription is activated for 30 days and you can scan any site.
Wallet
Additional pages that are credited to a separate balance. For checking large sites.
200 ₽
Number of pages
An active PRO subscription is required.
We use cookies. By continuing to use the site, you agree to the processing of personal data in accordance with privacy policy. I agree