<<
>>

Синтаксис: размечайте, как хотите

Некоторые языки программирования, например Python, обязывают писать инструкции специфическим образом. Обязательно использовать пробелы для отступа кода – пробелы и переносы строк имеют значение.

Другие языки программирования (например, JavaScript) не обращают никакого внимания на форматирование – сколько пробелов в начале строки, совершенно неважно.

Если хотите бесплатно развлечься вечером, соберите в одной комнате несколько программистов и произнесите слова: «табы или пробелы». Ближайшие несколько часов можете греться от жарких споров, которые разгорятся немедленно.

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

Пробелы и переносы строк не важны для разметки. Если вы хотите ставить перенос строки и отступ при каждом вложенном элементе, пожалуйста, но ни браузеры, ни валидаторы этого не требуют. Это не значит, впрочем, что разметку можно писать совсем уж как угодно.

Некоторые версии разметки обязывают к более строгому стилю написания, чем другие.

До XHTML 1.0 не имело никакого значения, пишете вы теги в верхнем или нижнем регистре. Не имело значения, закавычивали вы атрибуты или нет. Для некоторых элементов даже не имело значения, ставите ли вы закрывающий тег.

XHTML 1.0 обязывает следовать синтаксису XML. Все теги должны быть написаны в нижнем регистре. Все атрибуты должны быть в кавычках. У всех элементов должен быть закрывающий тег.

В особенном случае самостоятельных элементов, например br, требование закрывающего тега заменяется требованием закрывающей косой черты:

.

В случае HTML5 все подходит. Прописные, строчные буквы, в кавычках, без кавычек, самозакрывающиеся элементы или нет – решение здесь полностью за вами.

Я использовал доктайп XHTML 1.0 в течение многих лет.

Мне нравится, что я должен писать в каком-то одном специфическом стиле, и мне нравится, что валидатор W3C обязывает меня писать в этом стиле. Теперь, когда я использую HTML5, я сам должен обязать себя писать в том стиле, в каком хочу.

Я понимаю, почему некоторым людям не нравится нетребовательность синтаксиса HTML5. Получается, что мы как будто закрываем глаза на годы, за которые накопились передовые практики. Некоторые даже говорят, что нестрогий синтаксис HTML5 поощряет плохую разметку. Я не думаю, что это так, но могу понять, почему это причина для волнения. Случилось то же самое, как если бы язык программирования, который обязывал использовать значимые пробелы и переводы строк, внезапно переключился бы на правила, которые позволили бы делать это не всегда, а с какими-то исключениями.

Лично у меня нет проблем с бессистемностью синтаксиса HTML5. Я смирился с тем, что мне придется самому обязывать себя писать так, как я хочу. Но мне хотелось бы видеть больше инструментов, которые позволили бы мне проверять, насколько моя разметка соответствует тому или иному стилю. В мире программирования такие инструменты называются «линтерами» – программы, которые отмечают ненадежные места в коде. Линтер для разметки отличается от валидатора, который проверяет соответствие разметки доктайпу; но было бы замечательно, если бы оба они могли быть соединены в одну подкачавшуюся и готовую работать машину для линтирования и валидации.

Кто напишет такую программу, заслужит вечное уважение и восхищение веб-разработчиков по всему миру.

<< | >>
Источник: Кит Джереми. HTML5 для веб-дизайнеров. 2013

Еще по теме Синтаксис: размечайте, как хотите:

  1. Хотите верьте, хотите нет
  2. Синтаксис рекламного текста
  3. Вы действительно хотите преуспеть?
  4. Куда вы хотите отправиться?
  5. Если вы хотите получить оценку
  6. Хотите узнать — какой Вы трейдер?
  7. Постановка целей: каких показателей вы хотите добиться?
  8. ВСЁ ЕЩЁ ХОТИТЕ БОЛЬШЕГО? - НЕКОТОРЫЕ СОВЕТЫ К ДЕЙСТВИЮ
  9. ГЛАВА 14. ШАГ 4: Решите, каким инвестором Вы хотите быть
  10. Что вы хотите? Что нужно сделать, чтобы этого достичь? Готовы ли вы заплатить необходимую цену?
  11. Вспомогательная аксиома № 3. Решите заранее, какую прибыль опт сделки хотите получить, а получив ее, немедленно закрывайте позицию
  12. Владимир Савенок. Как составить личный финансовый план и как его реализовать, 2011
  13. Джон Янч. Продавец нового времени. Думай как маркетер – продавай как звезда, 2015
  14. 1.1. ОСОБЕННОСТИ МАКРОЭКОНОМИКИ КАК ОБЪЕКТА ИЗУЧЕНИЯ И КАК НАУКИ
  15. Глава 1. МАКРОЭКОНОМИКА КАК ОБЪЕКТ ИЗУЧЕНИЯ И КАК НАУКА
  16. Сколько и как платить маркетеру? Как его мотивировать?
  17. Земля как главная вещь и как принадлежность
  18. Принятие решений как процесс и как методика