Лучший опыт

21 рекомендация по HTML.

Переходим сразу к делу. Создание ссылок для контактов При помощи HTML создаются рабочие ссылки на электронную почту, телефонный номер, SMS: <!-- Ссылка на почту --> <a href="mailto:[email protected]"> Send Email </a> <!-- Ссылка на телефон --> <a href="tel:+1234567890"> Call Us </a> <!-- Ссылка на SMS --> <a href="sms:+1234567890"> Send SMS </a> Создание сворачиваемого контента Тегами <details> и <summary> в веб-страницу включается сворачиваемое содержимое, первым тегом со?
21 рекомендация по HTML...

Переходим сразу к делу.

Создание ссылок для контактов

При помощи HTML создаются рабочие ссылки на электронную почту, телефонный номер, SMS:

<!-- Ссылка на почту -->
<a href="mailto:[email protected]"> Send Email </a>

<!-- Ссылка на телефон -->
<a href="tel:+1234567890"> Call Us </a>

<!-- Ссылка на SMS -->
<a href="sms:+1234567890"> Send SMS </a>

Создание сворачиваемого контента

Тегами <details> и <summary> в веб-страницу включается сворачиваемое содержимое, первым тегом создается контейнер для скрытого контента, вторым  —  предоставляется интерактивная метка для переключения видимости этого контента:

<details>
<summary>Click to expand</summary>
<p>This content can be expanded or collapsed.</p>
</details>

Использование семантических элементов

Вместо несемантических элементов выбирайте для сайтов семантические. С ними код становится информативным, совершенствуются структура, доступность и поисковая оптимизация:

Группирование элементов формы

Тегом <fieldset> связанные элементы формы объединяются в группы, а тегом <legend> вместе с <fieldset> определяется заголовок для тега <fieldset>, так создаются более эффективные и доступные формы:

<form>
<fieldset>
<legend>Personal details</legend>
<label for="firstname">First name:</label>
<input type="text" id="firstname" name="firstname" />
<label for="email">Email:</label>
<input type="email" id="email" name="email" />
<label for="contact">Contact:</label>
<input type="text" id="contact" name="contact" />
<input type="button" value="Submit" />
</fieldset>
</form>

Совершенствование выпадающих меню

Тегом <optgroup> объединяются связанные параметры HTML-тега <select> в больших выпадающих меню или длинных списках параметров:

<select>
<optgroup label="Fruits">
<option>Apple</option>
<option>Banana</option>
<option>Mango</option>
</optgroup>
<optgroup label="Vegetables">
<option>Tomato</option>
<option>Broccoli</option>
<option>Carrot</option>
</optgroup>
</select>

Доработка видеопрезентации

Пока пользователь не проигрывает видео, атрибутом poster и элементом <video> показывается изображение:

<video controls poster="image.png" width="500">
<source src="video.mp4" type="video/mp4 />
</video>

Поддержка множественного выбора

Благодаря атрибуту multiple с элементами <input> и <select> пользователь выбирает/вводит сразу несколько значений:

<input type="file" multiple />
<select multiple>
<option value="java">Java</option>
<option value="javascript">JavaScript</option>
<option value="typescript">TypeScript</option>
<option value="rust">Rust</option>
</select>

Отображение надстрочного и подстрочного текста

Элементами <sub> и <sup> отображается соответственно надстрочный и подстрочный текст:

Создание ссылок для загрузки

Атрибутом download с элементом <a> указывается, что при нажатии на ссылку пользователь не переходит на связанный с нею ресурс, а загружает его:

<a href="document.pdf" download="document.pdf"> Download PDF </a>

Определение базового URL-адреса для относительных ссылок

Тегом <base> определяется базовый URL-адрес для всех относительных URL-адресов на веб-странице, чем упрощаются загрузка ресурсов и навигация:

<head>
<base href="https://shefali.dev" target="_blank" />
</head>
<body>
<a href="/blog">Blogs</a>
<a href="/get-in-touch">Contact</a>
</body>

Контроль загрузки изображения

Атрибутом loading с элементом <img> контролируется загрузка браузером изображения, имеются значения eager, lazy, auto  —  немедленная, отложенная и автозагрузка:

<img src="picture.jpg" loading="lazy">

Управление функционалом перевода

Атрибутом translate указывается, переводить ли содержимое элемента средствами перевода браузера:

<p translate="no">
This text should not be translated.
</p>

Максимальная длина ввода

Атрибутом maxlength задается максимальное количество символов поля ввода:

<input type="text" maxlength="4">

Минимальная длина ввода

Атрибутом minlength задается минимальное количество символов поля ввода:

<input type="text" minlength="3">

Редактирование контента

Атрибутом contenteditable обозначается доступность содержимого элемента для редактирования пользователями:

<div contenteditable="true">
You can edit this content.
</div>

Проверка орфографии

Атрибутом spellcheck с элементами <input>, элементами для редактирования содержимого и элементами <textarea> в браузере включается и отключается проверка орфографии:

<input type="text" spellcheck="true"/>

В целях доступности и поисковой оптимизации

Всегда добавляйте к изображениям информативные атрибуты alt с альтернативным описанием, на случай если изображение не покажется:

<img src="picture.jpg" alt="Description for the image">

Определение целевого поведения для ссылок

Атрибутом target указывается, где отображается связанный ресурс при нажатии:

<!-- Открывается в том же фрейме -->
<a href="https://shefali.dev" target="_self">Open</a>

<!-- Открывается в новом окне или вкладке -->
<a href="https://shefali.dev" target="_blank">Open</a>

<!-- Открывается в родительском фрейме -->
<a href="https://shefali.dev" target="_parent">Open</a>

<!-- Открывается во всем теле окна -->
<a href="https://shefali.dev" target="_top">Open</a>

<!-- Открывается в именованном фрейме -->
<a href="https://shefali.dev" target="framename">Open</a>

Дополнительная информация об элементе

Она предоставляется атрибутом title, когда пользователь наводит на элемент курсор:

<p title="World Health Organization">WHO</p>

Прием конкретных типов файлов

Атрибутом accept с элементом <input> указываются принимаемые сервером типы файлов, и только для типа файла:

<input type="file" accept="image/png, image/jpeg" />

Оптимизация загрузки видео

Чтобы видеофайлы воспроизводились плавнее, атрибутом preload с элементом <video> загрузка ускоряется:

<video src="video.mp4" preload="auto">
Your browser does not support the video tag.
</video>