Уроки
-
Введение
-
SEO
- Кликабельность снипета в поисковых системах
-
Индексация
-
Заголовки H1-H6
Атрибут «alt» у картинок
Атрибут Title у ссылок
Содержание robots.txt
Дублирующийся «title»
Дублирующийся «description»
Человеко понятное название картинки
Правила форматирования текста на странице
Требования и рекомендации формата микроразметки
Валидация микроразметки Яндекс и Google
Человеко понятный формат ссылок
Ошибки в Robots.txt
Содержание карты сайта
Файл карты сайта
Требования к форматированию ссылок
Тег Hreflang
Тег «canonical»
Орфография интерактивных элементов интерфейса
-
Скорость
-
Сократите количество сетевых запросов
-
Переизбыток маленьких картинок
Группировка CSS файлов
Группировка JavaScript файлов
Переизбыток файлов шрифтов
Перенаправления при загрузке файлов
Наличие сквозных CSS, JS файлов
Загрузка дубликатов файлов
Использование JavaScript фасадов
Перенаправление JavaScript кодом
Редирект с/на www версию
Использование технологии спрайтов
Корректное подключение видеоплеера
- Общая оценка
- Настройте сервер
- Ускорьте показ первого содержимого
-
Сократите размер графических файлов
-
Минификация встроенного JavaScript кода страницы
Минификация встроенного CSS кода страницы
Минификация картинок без потери качества
Суммарный размер всех картинок на странице
Оптимизация шрифтов
Переизбыток монохромных иконок
Наличие монохромного шрифта
Оптимизация data:URL картинок
Формат анимированных изображений MP4, WEBM, SVG вместо GIF и WEBP
Обрезка однотонных полей у изображений
Использование WebP формата в изображениях
Слишком качественные картинки без использования сжатия
Подходящий битрейт видео
Избыточно крупные картинки
-
Быстродействие сервера
-
Время генерации HTML кода
Оптимальное время загрузки файлов с сервера
Время загрузки файлов с сервера под нагрузкой
- Исправьте блокировки
- Сократите объём кода
-
Сократите количество сетевых запросов
- Мобильная адаптация
-
Программные ошибки
- Код
- Работа почты
- Доступность
- Настройки сервера
-
Удобство
- Читаемость текста
- Интерфейс
- Визуальные дефекты
- Взаимодействие с другими программами
- Фавикон изображения
-
Уязвимости
- Код
-
Настройки сервера
-
Загрузка всех файлов страницы по HTTPS
Заголовок Strict-https для повышения безопасности
Закрытый доступ к служебным файлам
Шифрованное IPv6 соединение
Включённый показ ошибок на севере
Корректность SSL сертификата
Доступность HTTPS
Перенаправления на защищённое
Уязвимости безопасного SSL соединения
HTTP заголовки для повышения безопасности
- Сторонние сервисы
Оптимальное время загрузки файлов с сервера
Время ответа сервера — это период от отправки запроса до получения первых байт информации. Страница сайта состоит из десятков файлов. Долгий ответ сервера на запрос о загрузке контента замедляет работу сайта.
Если задержка в обработке запроса имеет периодический характер, то значит проблема в высокой нагрузке. Текущих ресурсов сервера не хватает, чтобы обслужить всех пользователей в пиковой нагрузке.
Вы можете ускорить отдачу файлов сервером следующими способами:
- Используйте HTTP2.
- Чтобы сервер не сжимал файл каждый раз перед его отдачей пользователю, используйте предварительное gzip сжатие или кеширование сжатых файлов. Так, единожды сжатые текстовые файлы не потребуют повторной обработки, что сильно сэкономит вычислительные ресурсы.
- Сократите размер заголовков. Файлы cookies отправляются при каждом запросе. Сократив их, вы уменьшите размер передаваемых по сети данных.
- Используйте более быстрый веб-сервер Nginx.
- Проверьте, что служебные процедуры вроде «Keep-Alive», рукопожатия SSL, заголовки кеширования настроены корректно. Убедитесь, что соединение с сервером устанавливается 1 раз и не сбрасывается после загрузки каждого файла.
Пример, демонстрирующий изменение времени загрузки страницы в зависимости от задержки при загрузке файлов:
Демонстрация
PHP код
HTML код
<?php
if(isset($_GET['t'])) {
switch($_GET['delay'] ?? '') {
case 1:
usleep(100000);
break;
case 2:
usleep(200000);
break;
default:
break;
}
header('Content-Type: image/jpeg');
echo file_get_contents('photo.jpg');
die;
}
$mode = $_GET['mode'] ?? '';
?><!DOCTYPE html>
<html>
<head>
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<style>
.product-grid {
display: grid;
grid-template-columns: 1fr 1fr 1fr 1fr;
font-size: 20px
}
.product-grid img {
width: 100%;
}
.product-grid .product {
position: relative;
}
.product-grid .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>');
}
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="./over_time.php">Файлы загружаются без задержки</a> <a class="btn <?=$mode === '1' ? 'active' : ''?>" href="./over_time.php?mode=1">Задержка 0.1 секунды</a> <a class="btn <?=$mode === '2' ? 'active' : ''?>" href="./over_time.php?mode=2">Задержка 0.2 секунды</a>
<p id="page-load">Тут отобразится время загрузки страницы (вызова события window.onload)</p>
<div class="product-grid">
<?php for($i = 0; $i < 20;++$i) { ?>
<div class="product">
<img src="./over_time.php?t=<?=microtime(true)+$i?>&delay=<?=$mode?>" onload="endLoading(this)" /><br />
Товар 1<br />
1000 руб.
</div>
<?php } ?>
</div>
</body>
</html>
<!DOCTYPE html>
<html>
<head>
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<style>
.product-grid {
display: grid;
grid-template-columns: 1fr 1fr 1fr 1fr;
font-size: 20px
}
.product-grid img {
width: 100%;
}
.product-grid .product {
position: relative;
}
.product-grid .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>');
}
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="./over_time.php">Файлы загружаются без задержки</a> <a class="btn " href="./over_time.php?mode=1">Задержка 0.1 секунды</a> <a class="btn " href="./over_time.php?mode=2">Задержка 0.2 секунды</a>
<p id="page-load">Тут отобразится время загрузки страницы (вызова события window.onload)</p>
<div class="product-grid">
<div class="product">
<img src="./over_time.php?t=1772868417.3327&delay=" onload="endLoading(this)" /><br />
Товар 1<br />
1000 руб.
</div>
<div class="product">
<img src="./over_time.php?t=1772868418.3327&delay=" onload="endLoading(this)" /><br />
Товар 1<br />
1000 руб.
</div>
<div class="product">
<img src="./over_time.php?t=1772868419.3327&delay=" onload="endLoading(this)" /><br />
Товар 1<br />
1000 руб.
</div>
<div class="product">
<img src="./over_time.php?t=1772868420.3327&delay=" onload="endLoading(this)" /><br />
Товар 1<br />
1000 руб.
</div>
<div class="product">
<img src="./over_time.php?t=1772868421.3327&delay=" onload="endLoading(this)" /><br />
Товар 1<br />
1000 руб.
</div>
<div class="product">
<img src="./over_time.php?t=1772868422.3327&delay=" onload="endLoading(this)" /><br />
Товар 1<br />
1000 руб.
</div>
<div class="product">
<img src="./over_time.php?t=1772868423.3327&delay=" onload="endLoading(this)" /><br />
Товар 1<br />
1000 руб.
</div>
<div class="product">
<img src="./over_time.php?t=1772868424.3327&delay=" onload="endLoading(this)" /><br />
Товар 1<br />
1000 руб.
</div>
<div class="product">
<img src="./over_time.php?t=1772868425.3327&delay=" onload="endLoading(this)" /><br />
Товар 1<br />
1000 руб.
</div>
<div class="product">
<img src="./over_time.php?t=1772868426.3327&delay=" onload="endLoading(this)" /><br />
Товар 1<br />
1000 руб.
</div>
<div class="product">
<img src="./over_time.php?t=1772868427.3327&delay=" onload="endLoading(this)" /><br />
Товар 1<br />
1000 руб.
</div>
<div class="product">
<img src="./over_time.php?t=1772868428.3327&delay=" onload="endLoading(this)" /><br />
Товар 1<br />
1000 руб.
</div>
<div class="product">
<img src="./over_time.php?t=1772868429.3327&delay=" onload="endLoading(this)" /><br />
Товар 1<br />
1000 руб.
</div>
<div class="product">
<img src="./over_time.php?t=1772868430.3327&delay=" onload="endLoading(this)" /><br />
Товар 1<br />
1000 руб.
</div>
<div class="product">
<img src="./over_time.php?t=1772868431.3327&delay=" onload="endLoading(this)" /><br />
Товар 1<br />
1000 руб.
</div>
<div class="product">
<img src="./over_time.php?t=1772868432.3327&delay=" onload="endLoading(this)" /><br />
Товар 1<br />
1000 руб.
</div>
<div class="product">
<img src="./over_time.php?t=1772868433.3327&delay=" onload="endLoading(this)" /><br />
Товар 1<br />
1000 руб.
</div>
<div class="product">
<img src="./over_time.php?t=1772868434.3327&delay=" onload="endLoading(this)" /><br />
Товар 1<br />
1000 руб.
</div>
<div class="product">
<img src="./over_time.php?t=1772868435.3327&delay=" onload="endLoading(this)" /><br />
Товар 1<br />
1000 руб.
</div>
<div class="product">
<img src="./over_time.php?t=1772868436.3327&delay=" onload="endLoading(this)" /><br />
Товар 1<br />
1000 руб.
</div>
</div>
</body>
</html>