Атрибут id | HTML | WebReference
Задаёт стилевой идентификатор — уникальное имя элемента, которое используется для изменения его стиля и обращения к нему через скрипты. Идентификатор в коде документа должен быть в единственном экземпляре, иными словами, встречаться только один раз.
Синтаксис
id="<имя идентификатора>"
Значения
Идентификатор состоит по меньшей мере из одного символа и не должен содержать пробел. В имя идентификатора допустимо включать цифры, символ подчёркивания, дефис и др.
В HTML4 идентификатор не должен начинаться с цифры и содержать другие символы, кроме дефиса, подчёркивания и точки. Придерживайтесь этих правил, если вам требуется взаимодействие идентификаторов с JavaScript или совместимость со старыми браузерами.
Значение по умолчанию
Пример
<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8">
<title>Атрибут id</title>
<style>
#help {
position: absolute; /* Абсолютное позиционирование */
right: 0; /* Положение элемента от правого края */
top: 20px; /* Положение от верхнего края */
width: 225px; /* Ширина блока */
padding: 5px; /* Поля вокруг текста */
background: #f0f0f0; /* Цвет фона */
}
</style>
</head>
<body>
<div>
Этот элемент помогает в случае, когда вы находитесь в осознании того
факта, что совершенно не понимаете, кто и как вам может помочь. Именно
в этот момент мы и подсказываем, что помочь вам никто не сможет.
</div>
</body>
</html>
Спецификация ?
Спецификация
Каждая спецификация проходит несколько стадий одобрения.
- Recommendation (Рекомендация) — спецификация одобрена W3C и рекомендована как стандарт.
- Candidate Recommendation (Возможная рекомендация) — группа, отвечающая за стандарт, удовлетворена, как он соответствует своим целям, но требуется помощь сообщества разработчиков по реализации стандарта.
- Proposed Recommendation (Предлагаемая рекомендация) — на этом этапе документ представлен на рассмотрение Консультативного совета W3C для окончательного утверждения.
- Working Draft (Рабочий проект) — более зрелая версия черновика после обсуждения и внесения поправок для рассмотрения сообществом.
- Editor’s draft (Редакторский черновик) — черновая версия стандарта после внесения правок редакторами проекта.
- Draft (Черновик спецификации) — первая черновая версия стандарта.
Особняком стоит живой стандарт HTML (Living) — он не придерживается традиционной нумерации версий, поскольку находится в постоянной разработке и обновляется регулярно.
×Браузеры
В таблице браузеров применяются следующие обозначения.
- — элемент полностью поддерживается браузером;
- — элемент браузером не воспринимается и игнорируется;
- — при работе возможно появление различных ошибок, либо элемент поддерживается с оговорками.
Число указывает версию браузреа, начиная с которой элемент поддерживается.
×Автор и редакторы
Автор: Влад Мержевич
Последнее изменение: 19.03.2018
Редакторы: Влад Мержевич
Все о селекторах идентификатора (id) в CSS
Разберем подробно понятие селектора идентификатора. Основная его задача на практике заключается в выделении некоторого компонента по уникальному обозначению, то есть атрибуту id. В коде обозначается значком «#» после которого следует его название.
В качестве примера разберем довольно частую задачу, которая заключается к присвоению блоку определенной высоты:
#superBlock { height: 200px; }
Данный селектор имеет много общих черт с селекторами класса. С его помощью, как и с помощью селектора класса, выбранному элементу можно присвоить определенный стиль или характеристики.
Пример: для начала работы с селектором id нужно создать атрибут, посредством которого будут присваиваться классы:
<ul> <li>Наша строка с уникальным стилем</li> <li>Другая строка</li> <li>Другая строка</li> </ul> <style> /* пееркрасим строку с в красный */ #active { color: red; } </style>
Стоит отметить то, что аналогично селектору класса, используя селектор id совместно с универсальным мы получаем бессмыслицу:
/* ниже два абсолютно тождественных стиля оформления */ *#important {} #important {}
Также важным является то, что селекторы id и типа можно объединять, что в свою очередь объединит свойства, присвоенные данным селекторам:
li#important { color: red; }
Данное правило справедливо только при употреблении такого id. Однако эффективность подобной конструкции мала, поскольку один и тот же id может встречаться на странице только один раз. Но все же этот пример имеет смысл в строго определенных случаях. К примеру, для элементов какого-то нетипичного списка.
Еще одна особенность в работе с селектором идентификатора – регистрозависимость, то есть принципиально важное различие в использовании заглавных и строчных символов.
Различие id и классов
Основное сходство заключается в способности селекторов идентификатора и класса присвоить разные стили одному и тому же тегу.
Теперь стоит перечислить их различия:
- первая особенность заключается в том, что селектор id имеет больший приоритет нежели класса и в случае пересечения их на одном и том же теге, оформление он получит от своего айдишника;
- идентификаторы присваиваются только одному конкретному элементу, в то время как класс может применяться к нескольким;
Ограничения в применении
Применение идентификаторов является рациональным при обращении к элементам в рамках скрипта. В следствие этого использование идентификаторов зачастую сопровождается применением скриптов. В тоже время id подчеркивается уникальность стиля элемента (тот факт, что что-то встречается в коде страницы лишь один раз). Ярким примером использования идентификаторов являются формы и динамические элементы интерфейса.
При прочих раскладах нам обычно подходит использование классов.
Оценок: 1 (средняя 5 из 5)
- 1005 просмотров
Понравилась статья? Расскажите о ней друзьям:
Курсы по CSS (в открытом доступе)
Уровень сложности:
Средний
Еще интересное
Почему не использовать #ID в CSS
Используйте ID по прямому назначению: для идентификации элементов. Для полей ввода, якорных ссылок или яваскрипта. Стили через #id не назначайте.
Почему нет
ID — уникальное значение, оно может быть на странице одно. Стили нельзя использовать повторно, что ухудшает масштабируемость проекта. А это идёт вразрез самой логике визуализации объектов.
На курсе html и css — это обязательное правило. Мы на практике разбираем более удобные форматы стилизации. Учимся писать гибкие, легко настраиваемые стили, с логичными переопределениями, которые не порождают конфликты.
Проблема 1: у #id высокий приоритет
У сайта есть шапка, внешний вид которой описан через #id. Шапка на сайте одна и проблемы вроде нет. Но, появляется задача внести изменение: во всех разделах оставить её синей, а в «Новостях» сделать жёлтой. И вот #id нам ставит первую подножку.
У атрибута .class
приоритет ниже #id
.
— Ха, я использую !important
, — Выкрикнул самодовольных мальчишка и решил задачу.
Пускай порадуется.
Проблема 2: #id проявится там, где вы не хотели
У нас есть блок с текстом, внизу которого нужно добавить социальные кнопки. Такие же кнопки есть в сайдбаре. Ничего нового делать не нужно, скопировать и вставить.
Выполняем и получаем под дых. При наведении ситуация усугубляется.
— Ха, я использую !important
, — Выкрикнул самодовольных мальчишка и решил проблему, как и в предыдущий раз.
Попробуйте исправить и вы, редактируя только код кнопок во вкладке «CSS».
Вместо того, чтобы заменить идентификаторы на классы и жить в гармонии, мы превращаем стили в неповоротливого монстра, нашпигованного !important
А если очень надо
Когда без ID никак, обратитесь к элементу, напрямую прописав атрибут: [id="id_name"]
. У такой записи низкий вес.
Но она выглядит костыльно и служит напоминанием: присваивать стили через ID — плохое решение.
CSS как обращаться к вложенному классу
Селекторы class и id
В примере выше мы имеем 3 селектора – это p, div span, ul li. То есть весь наш файл стилей состоит из селекторов и их свойств. Наиболее удобно и наглядно, особенно новичкам, брать за селектор имя класса (class) тега или уникальный идентификатор (id) тега. Чтобы присвоить класс или идентификатор какому-либо тегу, мы должны указать их среди атрибутов этого тега. У конкретного тега может быть максимум 1 идентификатор и бесконечное число классов. Пример:
<div>текст в первом диве</div> <div>текст во втором диве</div> <div>текст в третьем диве</div>
<div>текст в первом диве</div> <div>текст во втором диве</div> <div>текст в третьем диве</div> |
На что стоит обратить внимание:
- Классы и идентификаторы можно присваивать любым (всем) тегам.
- Каждый id уникален и не может повторяться в пределах одной страницы, в отличие от классов!
- Один и тот же класс может быть присвоен любым тегам и может повторяться любое количество раз на странице.
- Если мы хотим задать конкретному тегу несколько классов, мы просто задаём их через пробел.
- Имена классов и идентификаторов могут совпадать, при этом кроме имени, ничего общего между ними не будет.
Как обратиться к классу или id в файле стилей (CSS)?
Смотрим пример:
#first {color: red;} <span>/* обращаемся к id с именем first */</span> .second {color: blue;} <span>/* обращаемся к классу с именем second */</span> #first .second {color: orange;} <span>/* обращаемся к классу с именем second, ТОЛЬКО если он находится ВНУТРИ тега с идентификатором first */</span> .first .third {color: grey;} <span>/* обращаемся к классу с именем third, ТОЛЬКО если он находится ВНУТРИ тега с классом first */</span>
#first {color: red;} <span>/* обращаемся к id с именем first */</span> .second {color: blue;} <span>/* обращаемся к классу с именем second */</span> #first .second {color: orange;} <span>/* обращаемся к классу с именем second, ТОЛЬКО если он находится ВНУТРИ тега с идентификатором first */</span> .first .third {color: grey;} <span>/* обращаемся к классу с именем third, ТОЛЬКО если он находится ВНУТРИ тега с классом first */</span> |
Поделитесь с друзьями
Также интересно:
- Сертификаты Битрикс
Итак, продолжаем настигать упущенное. Наш сотрудник активно сдает тесты по Битриксу и получает сертификаты. Главная…
- SEO Рязань
Что такое SEO продвижение сайта? Часто приходится слышать этот вопрос от заказчиков сайтов, лендингов и…
- Партнеры Битрикс
Мы давно начали работать с платформой Битрикс, но вот наконец решили оформить партнерские отношения. Разработка…
CSS id и class // Вебшкола онлайн
Селекторы id и class
Кроме форматирования обычных HTML элементов (например, h2, p и тд), CSS позволяет вам указать свои собственные селекторы, называемые «id» и «class», которые позволяют применять свойства CSS к элементам определенного блока страницы. Например, вы можете присвоить класс всем ссылкам в блоке навигации и другой класс блоку содержимого страницы. После этого при помощи CSS вы можете присвоить различный стиль ссылкам в блоке навигации и блоке контента. На этом сайте вы можете убедиться в том, что ссылки в блоках навигации слева и справа имеют различный стиль, отличающийся от стиля ссылок в блоке контента.
Селектор id
Селектор id используется для определения стиля единственного, уникального элемента страницы.
Селектор id использует атрибут id HTML-элемента и определяется знаком «#».
Стилевое правило в примере ниже будет применено к элементу с :
Пример
HTML
<p>К этому параграфу будет применен стиль id para1, то есть текст параграфа будет выровнен по центру и будет окрашен в красный цвет.</p>
CSS
#para1
text-align:center;
color:red;
}
Совет: название id не должно начинаться с цифры, так как такой id не будет работать в firefox.
Селектор class
Селектор class используется для определения стиля групп элементов. В отличие от селектора id, селектор class обычно используют для форматирования нескольких элементов.
Это позволяет вам задавать одинаковый стиль для любого html-элемента с одинаковым классом.
Селектор class использует атрибут HTML class и определяется знаком «.»
В примере ниже, текст всех html-элементов с будет выровнен по центру:
Пример
HTML
<h2>Текст этого заголовка будет выровнен по центру</h2>
<p>Текст этого параграфа также будет выровнен по центру.</p>
CSS
.center {text-align:center;}
Вы можете указать, что стиль класса должен применяться только к одному элементу HTML.
В примере ниже, текст всех элементов p (параграф) с будет выровнен по центру:
Пример
p.center {text-align:center;}
Совет: название класса не должно начинаться с цифры, так как такие названия поддерживаются только в Internet Explorer.
Понравилась запись? Сказать «Спасибо» очень просто, поделитесь записью в социальных сетях!