Недавно я был сильно озадачен скоростью загрузки своего сайта. Ресурс, некогда загружающийся за 0.4 секунды, начал виснуть в среднем полторы-две секунды, а иногда и по 4!
Сразу отбросив варианты "да это в хостинге дело" и "их CDN как-то неправильно работает", я ринулся искать подтверждение своей криворукости. Первым делом прогнал сайт через Google PageSpeed Insights. Для своих тестов я взял последнюю статью в блоге: https://ydmitry.ru/blog/prezentatsiya-material-design-lite/. ... ну и увидел ужасающие 44 /100 по скорости (зато 97/100 удобство). Сразу бросилось в глаза:
"Подождите" - подумал я, точно помню, что JS перемещается в конец страницы.
Пришло время невообразимых костылей!
Открываем шаблон сайта и находим блок head. В нем:
<head> <meta name="viewport" content="width=device-width, initial-scale=1"> <title><?$APPLICATION->ShowTitle()?></title> <link rel="icon" href="<?=SITE_TEMPLATE_PATH?>/img/favicon1.ico" type="image/vnd.microsoft.icon"/> <link rel="stylesheet" href="//maxcdn.bootstrapcdn.com/font-awesome/4.3.0/css/font-awesome.min.css"> <?$APPLICATION->ShowHead();?> <?IncludeTemplateLangFile(__FILE__);?> </head>
Сразу бросается в глаза неправильное подключение стилей, но в целом неплохо. Все скрипты подключаются в футере:
<?$APPLICATION->AddHeadScript("/bower_components/jquery/dist/jquery.js")?> <?$APPLICATION->AddHeadScript("https://google-code-prettify.googlecode.com/svn/loader/run_prettify.js?skin=desert")?> <?$APPLICATION->AddHeadScript("/js/my.js")?>
На этом все. Первым же делом подключаю font-awesome правильно:
<?$APPLICATION->SetAdditionalCSS("//maxcdn.bootstrapcdn.com/font-awesome/4.3.0/css/font-awesome.min.css");?>
Но проблема не может быть только в этом. Скрипты выводятся в шапке и за это несет ответственность
$APPLICATION->ShowHead(). Можно было бы перенести вызов функции из шапки в футер, но тогда мы столкнемся с кучей ошибок:
Если загуглить проблему, все решения сводятся к тому, что нужно перенести ShowHead обратно наверх, а нас это принципиально не устраивает.
Будем выводить скрипты и стили вручную. ShowHead легко заменяется несколькими методами:
<meta http-equiv="Content-Type" content="text/html; charset=<?=LANG_CHARSET;?>" /> <?$APPLICATION->ShowMeta("keywords")?> <?$APPLICATION->ShowMeta("description")?> <?$APPLICATION->ShowCSS();?> <?$APPLICATION->ShowHeadStrings()?> <?$APPLICATION->ShowHeadScripts()?>
Первые четыре добавим в блок head, оставшиеся два поместим в футер. Перезагружаем страницу, ничего не сломалось, стили и скрипты грузятся в футере. Все отлично!? А нет, 67 ошибок "Uncaught ReferenceError: BX is not defined" и "Uncaught ReferenceError: BXHotKeys is not defined" остались.
Я немного поэкспериментировал и заметил, что ошибки валятся только под админкой, у обычных смертных все ок. Ну чтож, это легко исправить. Пишем два условия.
В шапку:
<? // Фикс множества багов "Uncaught ReferenceError: BXHotKeys is not defined" для админа if ($USER->IsAdmin()) { $APPLICATION->ShowHeadStrings(); } ?>
В футер:
<? // Фикс множества багов "Uncaught ReferenceError: BXHotKeys is not defined" для админа if (!$USER->IsAdmin()) { $APPLICATION->ShowHeadStrings(); } ?>
Вуаля. Грабли появились, ошибки исчезли! Если перестали отрабатывать какие-то скрипты в шаблонах компонентов (слайдеры, галереи и др.), просто создайте файл
script.js рядом с template.php нужного шаблона и переместите код в него. Файл автоматически подключится шаблоном. Проверим скорость загрузки.
С ShowHead:
Без ShowHead:
Да, все еще есть над чем работать, но прогресс налицо. После некоторого ожидания, видим положительную тенденцию:
Для полноты картины вот что получилось в файле header.php:
<head> <title><?$APPLICATION->ShowTitle()?></title> <!-- Meta --> <meta http-equiv="Content-Type" content="text/html; charset=<?=LANG_CHARSET?>"> <meta name="viewport" content="width=device-width, initial-scale=1"> <?$APPLICATION->ShowMeta("keywords")?> <?$APPLICATION->ShowMeta("description")?> <!-- !Meta --> <!-- CSS --> <?$APPLICATION->ShowCSS();?> <!-- !CSS --> <link rel="icon" href="<?=SITE_TEMPLATE_PATH?>/img/favicon1.ico" type="image/vnd.microsoft.icon"/> <?$APPLICATION->SetAdditionalCSS("//maxcdn.bootstrapcdn.com/font-awesome/4.3.0/css/font-awesome.min.css");?> <? // Фикс множества багов "Uncaught ReferenceError: BXHotKeys is not defined" для админа if ($USER->IsAdmin()) { $APPLICATION->ShowHeadStrings(); } ?> <?IncludeTemplateLangFile(__FILE__);?> </head>
footer.php
<?$APPLICATION->AddHeadScript("/bower_components/jquery/dist/jquery.js")?> <?$APPLICATION->AddHeadScript("https://google-code-prettify.googlecode.com/svn/loader/run_prettify.js?skin=desert")?> <!-- Scripts --> <? if (!$USER->IsAdmin()) { $APPLICATION->ShowHeadStrings(); } ?> <?$APPLICATION->ShowHeadScripts();?> <!-- !Scripts --> </body> </html>