Уроки
-
Введение
-
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 формата в изображениях
Слишком качественные картинки без использования сжатия
Подходящий битрейт видео
Избыточно крупные картинки
- Быстродействие сервера
- Исправьте блокировки
- Сократите объём кода
-
Сократите количество сетевых запросов
- Мобильная адаптация
-
Программные ошибки
- Код
- Работа почты
- Доступность
- Настройки сервера
-
Удобство
- Читаемость текста
- Интерфейс
- Визуальные дефекты
- Взаимодействие с другими программами
- Фавикон изображения
-
Уязвимости
- Код
-
Настройки сервера
-
Загрузка всех файлов страницы по HTTPS
Заголовок Strict-https для повышения безопасности
Закрытый доступ к служебным файлам
Шифрованное IPv6 соединение
Включённый показ ошибок на севере
Корректность SSL сертификата
Доступность HTTPS
Перенаправления на защищённое
Уязвимости безопасного SSL соединения
HTTP заголовки для повышения безопасности
- Сторонние сервисы
Загрузка файлов отложено или по востребованию
В первую очередь нужно загружать тот контент, который расположен на первом экране. Так пользователь быстрее приступит к изучению сайта, что повысит конверсию. Загрузку всего остального содержимого нужно отложить. Чтобы это сделать, вызывайте подгрузку тяжеловесных скриптов и сервисов в событии window.onload или в момент их востребования.
Отложенная подгрузка счётчиков аналитики
Хоть компании-поставщики систем аналитики и рекомендуют загружать их код как можно раньше, но технических объяснений, почему это надо делать, не предоставляют. Поэтому можно и нужно подгружать счётчики отложено.
Отложить загрузку Яндекс метрики можно вот так:
window.addEventListener("load", function() {
(function(m,e,t,r,i,k,a){m[i]=m[i]||function(){(m[i].a=m[i].a||[]).push(arguments)};
m[i].l=1*new Date();
for (var j = 0; j < document.scripts.length; j++) {if (document.scripts[j].src === r) { return; }}
k=e.createElement(t),a=e.getElementsByTagName(t)[0],k.async=1,k.src=r,a.parentNode.insertBefore(k,a)})
(window, document, "script", "https://mc.yandex.ru/metrika/tag.js", "ym");
ym(123123123, "init", {
clickmap:true,
trackLinks:true,
accurateTrackBounce:true,
webvisor:true
});
});
Гугл аналитикс вот так:
window.addEventListener("load", function() {
(function(m,e,t,r,i,k,a){m[i]=m[i]||function(){(m[i].a=m[i].a||[]).push(arguments)};
m[i].l=1*new Date();
for (var j = 0; j < document.scripts.length; j++) {if (document.scripts[j].src === r) { return; }}
k=e.createElement(t),a=e.getElementsByTagName(t)[0],k.async=1,k.src=r,a.parentNode.insertBefore(k,a)})
(window, document, "script", "https://www.googletagmanager.com/gtag/js?id=G-123123123", "ga");
window.dataLayer = window.dataLayer || [];
function gtag(){dataLayer.push(arguments);}
gtag('js', new Date());
gtag('config', 'G-123123123');
});
Помимо Яндекс метрики и Гугл аналитикс в событии window.onload нужно подгружать все рекламные и реферальные счётчики.
Картографические сервисы, онлайн консультанты, системы сторонней авторизации (VK ID, Yandex ID и т.д.)
Если карта расположена на первом экране, то её нужно подгружать сразу, если ниже то в событии window.onload.
Делается это так:
window.addEventListener("load", (event) => {
setTimeout(function() {
// Тут вызов кода загрузки
}, 50);
});
или jQuery версия
$(window).on("load", function(event) {
setTimeout(function() {
// Тут вызов кода загрузки
}, 50);
})
Каптчи
Скрипт каптчи нужно инициировать в момент начала заполнения полей формы. То есть по событию focus на любом из полей формы.
Вот jQuery код, который инициирует яндекс каптчу для формы когда пользователь начинает её заполнять:
/*Функция которая подключает каптчу на форму*/
function initSmCaptcha(form) {
// Проверяем, была ли ранее инициирована каптча
if(form.is('[sm-captcha-applied]')) return;
// Добавляем инициацию каптчи на событии focus
form.find('[type=text], [type=tel], [type=email]').focus(function() {
form.attr('sm-captcha-applied', '');
// Добавляем уникальный для формы блок для отображения каптчи
var containerId = 'captcha-container-'+(new Date).getTime();
form.append('<div id="'+containerId+'"></div>');
var renderCaptcha = function() {
window.smartCaptcha.render(containerId, {
sitekey: 'SMARTCAPTCHA_CLIENT_KEY',
invisible: true
});
};
if (!window.smartCaptcha)
// Загружаем код каптчи
$.getScript('https://captcha-api.yandex.ru/captcha.js', renderCaptcha);
else
renderCaptcha();
});
}