Дочерние и контекстные CSS селекторы. Значение тега doctype: Зачем он нужен и какой выбрать

Влад Мержевич

Дочерним называется элемент, который непосредственно располагается внутри родительского элемента. Чтобы лучше понять отношения между элементами документа, разберём небольшой код (пример 12.1).

Пример 12.1. Вложенность элементов в документе

HTML5 CSS 2.1 IE Cr Op Sa Fx

Lorem ipsum

Lorem ipsum dolor sit amet, consectetuer adipiscing elit, sed diem nonummy nibh euismod tincidunt ut lacreet dolore magna aliguam erat volutpat.

Ut wisis enim ad minim veniam, quis nostrud exerci tution ullamcorper suscipit lobortis nisl ut aliquip ex ea commodo consequat.

В данном примере применяется несколько контейнеров, которые в коде располагаются один в другом. Нагляднее это видно на дереве элементов, так называется структура отношений тегов документа между собой (рис. 12.1).

Рис. 12.1. Дерево элементов для примера

На рис. 12.1 в удобном виде представлена вложенность элементов и их иерархия. Здесь дочерним элементом по отношению к тегу

выступает тег

Вместе с тем тег не является дочерним для тега

, поскольку он расположен в контейнере

Вернёмся теперь к селекторам. Дочерним селектором считается такой, который в дереве элементов находится прямо внутри родительского элемента. Синтаксис применения таких селекторов следующий.

Селектор 1 > Селектор 2 { Описание правил стиля }

Стиль применяется к Селектору 2, но только в том случае, если он является дочерним для Селектора 1.

Если снова обратиться к примеру 12.1, то стиль вида P > EM { color: red } будет установлен для первого абзаца документа, поскольку тег находится внутри контейнера

И не даст никакого результата для второго абзаца. А все из-за того, что тег во втором абзаце расположен в контейнере , поэтому нарушается условие вложенности.

По своей логике дочерние селекторы похожи на селекторы контекстные. Разница между ними следующая. Стиль к дочернему селектору применяется только в том случае, когда он является прямым потомком, иными словами, непосредственно располагается внутри родительского элемента. Для контекстного селектора же допустим любой уровень вложенности. Чтобы стало понятно, о чем идет речь, разберём следующий код (пример 12.2).

Пример 12.2. Контекстные и дочерние селекторы

HTML5 CSS 2.1 IE Cr Op Sa Fx

Дочерние селекторы

Lorem ipsum dolor sit amet, consectetuer adipiscing elit, sed diem nonummy nibh euismod tincidunt ut lacreet dolore magna aliguam erat volutpat.

Результат данного примера показан на рис. 12.2.

Рис. 12.2. Цвет текста, заданный с помощью дочернего селектора

На тег в примере действуют одновременно два правила: контекстный селектор (тег расположен внутри

) и дочерний селектор (тег является дочерним по отношению к

). При этом правила являются равносильными, поскольку все условия для них выполняются и не противоречат друг другу. В подобных случаях применяется стиль, который расположен в коде ниже, поэтому курсивный текст отображается красным цветом. Стоит поменять правила местами и поставить DIV I ниже, как цвет текста изменится с красного на зеленый.

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

Удобнее всего применять указанные селекторы для элементов, которые обладают иерархической структурой — сюда относятся, например, таблицы и разные списки. В примере 12.3 показано изменение вида списка с помощью стилей. За счёт вложения одного списка в другой получаем разновидность меню. Заголовки при этом располагаются горизонтально, а набор ссылок — вертикально под заголовками (рис. 12.3).

Рис. 12.3. Список в виде меню

Для размещения текста по горизонтали к селектору LI добавляется стилевое свойство float . Чтобы при этом разделить между собой стиль горизонтального и вертикального списка и применяются дочерние селекторы (пример 12.3).

Пример 12.3. Использование дочерних селекторов

HTML5 CSS 2.1 IE Cr Op Sa Fx

Дочерние селекторы

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

Вопросы для проверки

1. Какой цвет будет у жирного курсивного текста в коде

Нормы освещённости построены на основе классификации зрительных работ по определенным количественным признакам.

При использовании следующего стиля?

P { color: green; }
B {color: blue; }
I {color: orange; }
B > I { color: olive; }
P > I { color: yellow; }

  1. Зелёный.
  2. Синий.
  3. Оранжевый.
  4. Оливковый.
  5. Жёлтый.

2. Какой элемент является родительским для тега ? </b></p> <ol><li><HEAD></li> <li><BODY></li> <li><HTML></li> <li><META></li> <li><!DOCTYPE></li> </ol><p><b>3. Для какого тега элемент <!DOCTYPE> выступает родителем? </b></p> <ol><li><HTML></li> <li><TITLE></li> <li><BODY></li> <li><HEAD></li> <li>Ни для одного тега.</li> </ol><h2>Ответы</h2> <p>1. Оливковый.</p> <p>3. Ни для одного тега.</p> <p><b><!DOCTYPE> </b> указывает, в соответствии с каким стандартом HTML написана ваша Web-страница.</p><br><table class="tbl1"><tbody><tr><th style="width:65%;">DOCTYPE </th><th>Описание </th> </tr><tr><td colspan="2"><b>HTML5 </b> </td> </tr><tr><td><!DOCTYPE html> </td> <td>Для всех документов. </td> </tr><tr><td colspan="2"><b>HTML 4.01 </b> </td> </tr><tr><td><!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01//EN"<br>"http://www.w3.org/TR/html4/strict.dtd"> </td> <td>Строгий синтаксис HTML. </td> </tr><tr><td><!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd"> </td> <td>Переходный синтаксис HTML. </td> </tr><tr><td><!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Frameset//EN" "http://www.w3.org/TR/html4/frameset.dtd"> </td> <td>В HTML-документе применяются фреймы. </td> </tr><tr><td colspan="2"><b>XHTML 1.0 </b> </td> </tr><tr><td><!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd"> </td> <td>Строгий синтаксис XHTML. </td> </tr><tr><td><!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> </td> <td>Переходный синтаксис XHTML. </td> </tr><tr><td><!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Frameset//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-frameset.dtd"> </td> <td>Документ написан на XHTML и содержит фреймы. </td> </tr><tr><td><!DOCTYPE html PUBLIC "-//WAPFORUM//DTD XHTML Mobile 1.0//EN" "http://www.wapforum.org/DTD/xhtml-mobile10.dtd"> </td> <td>XHTML мобильного профиля, добавляет специфические элементы для мобильных телефонов. </td> </tr><tr><td colspan="2"><b>XHTML 1.1 </b> </td> </tr><tr><td><!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.1//EN"<br>"http://www.w3.org/TR/xhtml11/DTD/xhtml11.dtd"> </td> <td>Никакого деления на виды это определение не имеет, синтаксис один и подчиняется четким правилам. </td> </tr></tbody></table><p>Итак, доктайпов существует несколько (строгие и переходные, для HTML и XHTML). Какой стандарт выбрать - вот в чем вопрос.</p> <h2>Стандарты HTML и XHTML</h2> <p>HTML - <a href="/funkcii-na-yazyke-paskal-tablica-standartnye-funkcii-pascal-struktura.html">стандартный язык</a> разметки Web-документов.</p> <p>В HTML 4.01 и HTML5 <a href="/obzor-android-smartfona-motorola-moto-z2-play-modulnost-vo-vtorom.html">внешний вид</a> страницы отделен от ее содержания. Содержание и структура (заголовки, абзацы, ссылки) задаются в HTML. Оформление (выравнивание, шрифты, цвета) задаются CSS-стилями.</p> <p>Например, тег <font> и атрибут align объявлены устаревшими.</p> <p>XHTML - расширяемый язык разметки Web-документов, созданный на базе XML . Стандарт XHTML представляет собой перечень различий между HTML 4.01 и XHTML.</p> <table class="tbl1"><tr><th style="width:38%;">Требования XHTML </th><th style="width:31%;">Нельзя </th><th style="width:31%;">Нужно </th> </tr><tr><td>Все теги должны быть закрыты. </td><td style="text-align:center;"><br> </td><td style="text-align:center;"><br /> </td> </tr><tr><td>Все теги, атрибуты и CSS-свойства должны быть набраны в нижнем регистре. </td><td style="text-align:center;"><img src='/dochernie-i-kontekstnye-css-selektory-znachenie-tega-doctype-zachem-on.html' loading=lazy> </td><td style="text-align:center;"><img src='/dochernie-i-kontekstnye-css-selektory-znachenie-tega-doctype-zachem-on.html' loading=lazy> </td> </tr><tr><td>Все значения атрибутов тегов должны быть заключены в кавычки. </td><td style="text-align:center;"><a href=http://сайт> </td><td style="text-align:center;"><a href="http://сайт"> </td> </tr><tr><td>Должна строго выполняться иерархия: первый тег закрывается последним. </td><td style="text-align:center;"><em><u>...</em></u> </td><td style="text-align:center;"><em><u>...</u></em> </td> </tr><tr><td>Блочный тег не может быть вложен в строчный. (После блочного элемента дальнейший вывод на странице осуществляется с новой строки. Строчный элемент перевода строки не делает.) </td><td style="text-align:center;"><div>...</div> </td><td style="text-align:center;"><div>...</div> </td> </tr><tr><td>Булевы атрибуты записываются в развёрнутой форме. </td><td style="text-align:center;"><option selected> </td><td style="text-align:center;"><option selected="selected"> </td> </tr><tr><td>У изображений обязательно должно быть указано описание </td><td style="text-align:center;"><img src='https://i2.wp.com/Ba.gif' loading=lazy> </td><td style="text-align:center;"><img src='https://i0.wp.com/Ba.gif' loading=lazy> </td> </tr></table><p>Достоинства языка XHTML - не строгость синтаксиса, а возможность придумывать собственные теги.</p> <p>Однако, 2 июля 2009 года Консорциум Всемирной паутины (W3C) сообщил о прекращении работ над XHTML 2.0, посчитав концепцию XHTML неверной. Группа программистов переключилась на работу над стандартом HTML5. И хотя стандарт HTML5 всё ещё не утверждён, на нём уже написано множество сайтов.</p> <p>Кому интересно, когда же HTML5 будет закончен, могут ознакомиться с первоисточниками:</p> <p>Официальная версия стандарта HTML5 находится по адресу: www.w3.org/TR/html5/</p> <p>Определимся с выбором. Сделать его несложно: использовать XHTML-стандарт не стоит, если вы не собираетесь расширять язык HTML.</p> <p>На!DOCTYPE, предназначенных для документов, использующих фреймы , останавливаться не будем: позавчерашний день.</p> <p>Следующий вопрос: какой выбрать синтаксис - строгий или переходный?</p> <h2>Строгий и переходный синтаксис HTML 4.01</h2> <p>Переходные синтаксисы существуют для того, чтобы облегчить переход на новый стандарт. Они пропустят многое из того, что строгий синтаксис посчитает ошибками.</p> <p>Понять, что тут к чему, проще на примере. Сначала зададим строгий синтаксис.</p> <h4>Строгий синтаксис</h4> <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01//EN" "http://www.w3.org/TR/html4/strict.dtd"> <head> <meta http-equiv="Content-Type" content="text/html; charset=utf-8"> <title>Проверка на валидность

Проверка на валидность

красным цветом.

Соответствие HTML-кода объявленному стандарту называют валидностью , а проверку на это соответствие - валидацией .

Чтобы отслеживать ошибки верстки, установим дополнение к FireFox Html Validator .

Откроем нашу страницу в браузере FireFox, наведем мышку на знак валидатора:

Двойной щелчок на знаке валидатора даст развернутый список ошибок:


Поменяем!DOCTYPE на переходный синтаксис:

Переходный синтаксис

Проверка на валидность

Проверка на валидность

Часть текста понадобилось выделить красным цветом.

Запускаем FireFox. Ошибок нет:


Вроде все прекрасно. Может, на этом и остановиться?

Мой совет: делать валидную верстку или в соответствии со строгим синтаксисом HTML 4.01, или сразу на HTML5. HTML надо использовать по его прямому назначению, а оформление оставить CSS. Кроме того, если у сайта валидная верстка, а он неправильно отображается в каком-либо браузере, то это однозначно проблема браузера. Новые версии браузера будут лучше соответствовать стандарту и не ошибаться в интерпретации валидного кода. Если же сложная верстка реализована невалидным способом, то нет гарантий, что новые версии браузеров не рассыпят ее на кусочки.

Не соблазняйтесь лояльностью переходного синтаксиса, только строгое соответствие стандартам!

Зачем нужна валидная верстка

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

- это минус на оценке качества сайта.

Именно из-за способности поисковых систем замечать любые недочеты HТML-кода и рекомендуется соблюдать валидность верстки. Кроме того, проверяя код на валидность, можно обнаружить наряду с мелкими недочетами еще и серьезные ошибки, которые были не замечаны ранее.



.

Решил проводить регулярные лекции и практические занятия со своими сотрудниками по программированию на PHP, MySQL, Javascript. А также другим технологиям необходимым для выпуска качественных сайтов. Начать решил с самого «верха», с HTML тэгов. Буду рад, любым комментариям:)
Сразу оговорюсь, что бОльшая часть информации я нашел в интернете, внизу статьи будут приведены ссылки на источники. Часть информации была переведена совместно с google translate.
Итак:

Почему так важен DOCTYPE

Вроде бы вы сделали все правильно, но ваш сайт почему-то не выглядит или не работает, как ожидалось, в последних версиях броузеров.
Вы написали правильный стандартный XHTML код и стандартный CSS. Вы воспользовались стандартной спецификацией для работы с DOM (Document Object Model), чтобы управлять динамическими элементами на странице. И все-таки, в броузерах, которые казалось бы сделаны с соблюдением именно этих стандартов, ваш сайт не работает. Скорей всего, ошибка кроется в неправильном заголовке DOCTYPE.
Эта небольшая статья расскажет вам о заголовках DOCTYPE, которые работают, а также объяснит практическое и теоретическое значение этого, казалось бы отвлеченного от реальности, тега.

Что такое DOCTYPE?

Согласно спецификациям HTML и XHTML тег DOCTYPE (что означает «объявление типа документа») сообщает валидатору, какую именно версию (X)HTML вы используете в своей странице. Этот тег должен всегда находиться в первой строке каждой страницы. Тег DOCTYPE - ключевой компонент web-страниц, претендующих на соответствие стандартам: без него ваш код и CSS не пройдут проверку валидатором.
Тег DOCTYPE также важен для правильного отображения и работы страницы в броузерах, соответствующих стандартам (Mozilla, IE5/Mac, и IE6/Win).
Тег DOCTYPE, в атрибутах которого указывается полный URI (полный web-адрес), сообщает броузерам, что страницу нужно вывести с соблюдением определенного стандарта или подвида этого стандарта.
Если вы будете пользоваться неполным тегом DOCTYPE, устаревшим его видом, или вообще забудете про него, броузер перейдет в «загадочный» (quirk) режим и будет исходить из предположения, что вы писали код страницы с ошибками и вольно отступали от стандартов, т.е. так, как писали в конце 90-ых годов.
В этом режиме броузер попытается разобрать вашу страницу по правилам обратной совместимости и выведет на экран, например, CSS так, как его вывел бы Internet Explorer 4-ой версии, а DOM будет работать так, как он работал именно в этом броузере (IE переключается в свой старый DOM, а Mozilla и Netscape 6 переключается вообще в бог знает что).
Понятно, что для вас эти выкрутасы не желательны. Но именно это вы и получите, если будете пользоваться неполным или неправильным тегом DOCTYPE.

Проблема

Когда создавали NN4, IE4 выполняли правила CSS не совсем в соответствии со стандартом. Реализация Netscape была просто ужасной, IE4 подошел к реализации стандарта лучше, но тем не менее, реализовал его не до конца. Хотя IE 5 Windows исправил множество ошибок IE 4, но оставались другие сбои в CSS (в основном в модели окон (window model)).
Поэтому, когда соответствие стандартам стало важным, W3C поставил производителей браузеров перед жестким выбором.
Приблизится к спецификации W3C было одним из решений проблемы, но если бы производители браузеров просто изменили реализацию CSS, чтобы соответствовать стандартам полностью, многие веб-сайты, «поползли» бы в большей или меньшей степени или оказались полностью неработоспособными. Такое сближение с соблюдением стандарта повлекло бы за собой проблемы. С другой стороны, не приведение к соответствию стандартов могло бы внести вечную путаницу в эпоху войны браузеров.

Решение

Поэтому решением этой проблемы было
  • позволить веб-разработчикам, которые знали о стандартах, выбирать какой режим использовать.
  • продолжать показывать старые страницы по старым (совместимым) правилам. (quirks mode)

Иными словами, всем браузерам необходимо было работать в двух режимах: режим совместимости для старых правил, и строгого режима для стандарта.
IE Mac был первым браузером использовавшим оба режима, а Windows IE 6, Mozilla, Safari, Opera и последовали его примеру.
IE 5 Windows, а также старые браузеры, как Netscape 4, постоянно заблокированы в режиме совместимости.

Решение о выборе, какой режим отображения требуется вызвать, было найдено в использовании «DOCTYPE» переключения. Согласно стандартам, любой (X) HTML документ должен иметь DOCTYPE который рассказывает всему миру, какой тип (X) HTML документа он использует.

Допустимые DTD

DOCTYPE Описание
HTML 4.01
Строгий синтаксис HTML.
Переходный синтаксис HTML.
В HTML-документе применяются фреймы.
XHTML 1.0
Строгий синтаксис XHTML.
Переходный синтаксис XHTML.
Документ написан на XHTML и содержит фреймы.
XHTML 1.1
Разработчики XHTML 1.1 предполагают, что он постепенно вытеснит HTML. Никакого деления на виды это определение не имеет, синтаксис один и подчиняется четким правилам.

HTML 4.01 DTDs

  • HTML 4.01 Strict - Не разрешает презентационной (оформительской) разметки, аргументируя тем, что этоим должен заниматься CSS.
  • Transitional DTD позволяет некоторые устаревшие аттрибуты и элементы
  • Если используются фреймы - должен быть использован frameset doctype

XHTML 1.0 DTDs

  • XHTML Strict DTD самый строгий существующий DTD: устаревшие (см ниже) теги не поддерживаются, и код должен быть написан правильно
  • XHTML Transitional DTD такой же как XHTML Strict DTD, но старые теги разрешены. Это НАИБОЛЕЕ ПОПУЛЯРНЫЙ в настоящий момент DTD.
  • XHTML Frameset DTD единственный XHTML DTD который поддерживает фреймы.

XHTML 1.1 DTD

Это новый DTD, который имеет строгость как у XHTML 1.0 Strict, и основан на фреймворке и модулях описанных в Modularization of XHTML (не стал искать что это такое:).

Статистика использования различных DTD

Староватая (с 2004 по 2008 гг), конечно, но новой не нашел.
www.qindex.info/Q_get.php?g_clss=forum&g_prcss=thrd&g_tmplt=&g_brd=5&g_thrd=128

Получается что Более 50% сайтов работают в режиме quirk mode - то есть в режиме IE4!

Устаревшие тэги и аттрибуты

Устаревшие тэги в алфавитном порядке

  • Используйте тег.
  • используйте CSS.
  • используйте CSS.
  • используйте CSS.
  • используйте
      .
    • используйте CSS.
    • используйте CSS.
    • используйте
      Или CSS.
    • замените тегом
        или CSS.
      • Используйте <pre>Или Source code.</li> <li><s>используйте<del> или <ins>.</li> <li><strike> используйте <del> или<ins>.</li> <li><u>используйте CSS.</li> <li><xmp> используйте <pre>И CSS стиль.</li> </ul><h3>Устаревшие HTML / XHTML аттрибуты тегов. Все они могут быть заменены CSS стилями.</h3><ul><li>align</li> <li>alink</li> <li>background</li> <li>bgcolor</li> <li>color</li> <li>hspace</li> <li>vlink</li> <li>vspace</li> </ul><h2>Разница между HTML и XHTML (указаны правила для XHTML)</h2><ul><li>Тэги должны быть написаны в нижнем регистре, вместо <img src='/dochernie-i-kontekstnye-css-selektory-znachenie-tega-doctype-zachem-on.html' loading=lazy>, как это было в HTML, нужно писать: <img src='https://i1.wp.com/resource/frankisboat.gif' height="227" width="389" loading=lazy></li> <li>Все теги должны закрываться, или с использованием тэга со слешем в паре, как параграф () например, или самозакрывающиеся тэги, как например (<br />).</li> <li>Все теги должны быть правильно вложены друг в друга, без перекрытий</li> <li>Не должны использоваться устаревшие теги</li> <li>Все аттрибуты должны быть набраны в нижем регистре</li> <li>Все значение аттрибутов должны быть заключены в одинарные или двойные кавычки</li> <li>Все аттрибуты должны использоваться в длинной форме, а не в короткой: disabled="disabled" в XHTML против DISABLED в HTML</li> <li>Структура должна быть отделена от контента. Например тег <p>Это часть контента (параграф) и вы не можете поместить в него например таблицу, потому что таблица это часть структуры (форматирования).</li> </ul><h3>Совместимость и IE8</h3> IE8 имеет четыре режима: IE 5.5 режим совместимости, IE 7 стандартный режим, IE в 8 <a href="/windows-8-bezopasnyi-rezhim-kak-voiti-v-bezopasnyi-rezhim-standartnyi-sposob.html">стандартном режиме</a> и IE 8 в режиме совместимости. <br> Выбор способа зависит от данных из различных источников: DOCTYPE, meta элементов, заголовков HTTP, периодически загружаемых данных от Microsoft (!), интрасети, настроек, сделанных пользователем, настроек сделанных администратором, наличия сайта в блеклисте microsoft и прочее! <h4>Схема (черт ногу сломит) определения в каком режиме работать браузеру IE8</h4>http://hsivonen.iki.fi/doctype/ie8-mode.pdf <h3>Источники информации</h3>http://hsivonen.iki.fi/doctype/ - подробная таблица выбора режима работы (все браузеры) <p>Приветствую Вас, уважаемые читатели! Сегодня короткий материал о специальном теге doctype. В статье вы узнаете что такое doctype, зачем он нужен и какие бывают версии html-документов.</p> <p>В любом правильном html-документе, первым элементом в <a href="/pochemu-dolgo-idet-proverochnyi-kod-na-aliexpress-chto-takoe.html">коде идет</a> специальная директива <b><!DOCTYPE> </b>.</p> <h3>Что такое DOCTYPE и зачем он нужен</h3> <p>Элемент <!doctype> — DTD (document type definition, описание типа документа) указывает тип документа, который используется при написании <a href="/chto-daet-kod-stranicy-v-vk-kak-izmenit-html-kod-stranicy-v.html">html кода</a>. Это непарный тег, который должен стоять самым первым в коде каждой страницы вашего сайта.</p> <p>Директива doctype необходима, чтобы браузер понимал как обрабатывать текущую веб-страничку, так как существует несколько версий языка HTML, а еще имеется XHTML (EXtensible HyperText Markup Language, расширенный язык разметки гипертекста), который похож на HTML, но различается с ним по синтаксису.</p> <p>Поэтому если вы хотите, чтобы ваш сайт отображался одинаково красиво и ровно во всех популярных браузерах, то обязательно указывайте эту директиву с версией <a href="/chto-takoe-yazyk-html-i-dlya-chego-on-nuzhen-html-chto-eto-takoe-i-s-chem-ego-edyat.html">языка html</a>, которую вы используете. Причем doctype следует указывать с общепринятыми правилами.</p> <p>Если вы будете пользоваться неполным тегом DOCTYPE, устаревшим его видом, или вообще забудете про него, то браузер перейдет в хитрый режим уловок - <b>quirks mode </b>. И возможно странички вашего сайта отобразятся правильно в каких-то браузерах, но не факт, что они будут выглядеть также аккуратно в других популярных браузерах.</p> <h3>Основные типы документов</h3> <p>Ниже приведены основные типы документов:</p> <table border="1" cellspacing="0" cellpadding="5"><tbody><tr><td><b>DOCTYPE </b> </td> <td><b>Описание </b> </td> </tr><tr><td colspan="2"><b>HTML 4.01 </b> </td> </tr><tr><td><!DOCTYPE HTML PUBLIC «-//W3C//DTD HTML 4.01//EN» «http://www.w3.org/TR/html4/strict.dtd»> </td> <td>Строгий синтаксис HTML </td> </tr><tr><td><!DOCTYPE HTML PUBLIC «-//W3C//DTD HTML 4.01 Transitional//EN» «http://www.w3.org/TR/html4/loose.dtd»> </td> <td>Переходный синтаксис HTML </td> </tr><tr><td><!DOCTYPE HTML PUBLIC «-//W3C//DTD HTML 4.01 Frameset//EN» «http://www.w3.org/TR/html4/frameset.dtd»> </td> <td>В HTML-документе применяются фреймы </td> </tr><tr><td colspan="2"><b>HTML 5 </b> </td> </tr><tr><td><!DOCTYPE html> </td> <td> </td> </tr><tr><td colspan="2"><b>XHTML 1.0 </b> </td> </tr><tr><td><!DOCTYPE html PUBLIC «-//W3C//DTD XHTML 1.0 Strict//EN» «http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd»> </td> <td>Строгий синтаксис XHTML </td> </tr><tr><td><!DOCTYPE html PUBLIC «-//W3C//DTD XHTML 1.0 Transitional//EN» «http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd»> </td> <td>Переходный синтаксис XHTML </td> </tr><tr><td><!DOCTYPE html PUBLIC «-//W3C//DTD XHTML 1.0 Frameset//EN» «http://www.w3.org/TR/xhtml1/DTD/xhtml1-frameset.dtd»> </td> <td>XHTML-документе применяются фреймы </td> </tr><tr><td colspan="2"><b>XHTML 1.1 </b> </td> </tr><tr><td><!DOCTYPE html PUBLIC «-//W3C//DTD XHTML 1.1//EN» «http://www.w3.org/TR/xhtml11/DTD/xhtml11.dtd»> </td> <td> </td> </tr></tbody></table><p>Пример использования <b>doctype для HTML5 </b>:</p> <p><!DOCTYPE html><br> <html><br> <head><br> <title>Страничка на HTML5</title><br> </head><br> <body><br> <p>Содержимое странички</p><br> </body><br> </html></p> <p>При выборе вида doctype следует иметь ввиду, что если вы пишите свой сайт в одном doctype, то не рекомендуется менять его в будущем на какой-то другой, так как скорей всего возникнут проблемы с <a href="/paket-obespecheniya-sovmestimosti-microsoft-office-dlya-formatov-failov-word-excel-i-powerpoint.html">правильным отображением</a> сайта в различных браузерах, так как со сменой doctype вы поменяете правила обработки тегов браузерами.</p> <p>Таким образом указав doctype вы указываете браузерам по каким правилам обрабатывать ваш html-код. Если же doctype не указать, то соответственно <a href="/sinhronizaciya-na-android-chto-eto-i-kak-nastroit-kak-vklyuchit.html">различные браузеры</a> будут интерпретировать ваши теги по разному и следовательно отображение вашего сайта в некоторых браузерах скорей всего будет не корректным.</p> <h3>Какой doctype использовать?</h3> <p>Выбрать какой doctype использовать стало проще с выходом <a href="/vatsap-na-telefon-poslednyaya-versiya-skachat-poslednyuyu-versiyu.html">последней версии</a> HTML5. Так как doctype html5 включает в себя правила <a href="/kak-otkatit-aifon-na-predydushchuyu-versiyu-kak-vernut.html">предыдущих версий</a> и возможность работы с тегами html4.</p> <p><!DOCTYPE html></p> <h3>Вывод</h3> <p>Подведем итоги:</p> <ul><li><span><b>DOCTYPE </b> — это элемент, который указывает <b>тип документа </b> и определяет правила по, которым браузер будет обрабатывать ваш html-код; </span></li> <li>элемент doctype всегда должен быть размещен в первой строчке документа;</li> <li>всегда указывайте doctype, иначе ваши странички могут отображаться некорректно;</li> <li>если не знаете какой doctype использовать, указывайте <b>doctype html5 </b>: <!doctype html>.</li> </ul><p>На этом все, желаю вам успехов! До новых встреч!</p> <p>Вы дошли до третьей части этой главы. Здесь вы узнаете, как использовать селекторы дочерних элементов в CSS, а также познакомитесь с некоторыми дополнительными псевдоклассами для более точной выборки.</p> <h2>Дочерние селекторы CSS</h2> <p>В предыдущей статье мы рассказывали о <a href="/vdovaya-posting-php-t-rodstvennye-svyazi-muzh-zhena-test-t-shcha-sv-kor.html">родственных связях</a> между элементами HTML-документа, в том числе и о дочерних элементах. Давайте посмотрим на примере, как эти связи можно использовать в CSS.</p> <p>Представьте, что вам нужно присвоить стиль только тем тегам <p>Которые являются дочерними по отношению к <body> , не затрагивая остальные <p> (например, <p>Дочерние по отношению к <div>).<br> Как это сделать? Очень просто: создадим дочерний селектор:</p><p>Body > p { color: #333; } </p><p>Обратите внимание на символ > после body . С помощью него вы указываете, что стиль применяется исключительно для дочерних тегов <p>Родителя <body> . Если символ убрать, то стиль применится абсолютно ко всем тегам <p>Которые находятся внутри тега <body> , хотя они могут и не являться для него дочерними.</p> <h3>Дополнительные псевдоклассы</h3> <p>В CSS3 существует ряд псевдоклассов для работы с дочерними элементами. Ниже приведено описание каждого из них, примеры использования, а также отличия между псевдоклассами вида «child» и «of-type».</p> <ul><li>:first-child – с помощью этого псевдокласса можно применить стиль к указанному элементу веб-страницы, при условии, что он является <b>первым </b> </li> <li>:last-child – стиль применяется к указанному элементу веб-страницы при условии, что он является <b>последним </b> дочерним элементом своего родителя;</li> <li>:nth-child – позволяет выбрать четные (even) и нечетные (odd) дочерние элементы; также с помощью данного псевдокласса можно стилизовать чередующиеся дочерние элементы, используя выражения вида an+b и числа;</li> <li>:only-child – применяется к дочернему элементу при условии, что тот является <b>единственным </b> ребенком у родителя;</li> <li>:first-of-type – стиль применяется к <b>первому элементу указанного типа </b> (даже если этот элемент не является первым дочерним для своего родителя и над ним находятся другие дочерние элементы других типов);</li> <li>:last-of-type – работает точно так же, как и предыдущий псевдокласс, с той лишь разницей, что стиль применяется к <b>последнему элементу указанного типа </b>;</li> <li>:nth-of-type – по принципу работы похож на:nth-child , но ориентируется на <b>тип </b> элемента;</li> <li>:only-of-type – применяется к дочернему элементу указанного типа при условии, что тот является у родителя <b>единственным ребенком своего типа </b>.</li> </ul><h4>Пример использования:first-child, :last-child и:nth-child</h4> <!-- HTML --> <div> <p>Первый ребенок</p> <p>Второй ребенок</p> <p>Третий ребенок</p> <table> <tr> <td>Нечетный номер</td> </tr> <tr> <td>Четный номер</td> </tr> <tr> <td>Нечетный номер</td> </tr> <tr> <td>Четный номер</td> </tr> </table> <p>Последний ребенок</p> </div> <p> /* CSS */ p:first-child { font-weight: bold; text-transform: uppercase; } p:last-child { font-style: italic; font-size: 0.8em; } p:nth-child(3) { color: red; } tr:nth-child(odd) { background-color: #A2DED0; } tr:nth-child(even) { background-color: #C8F7C5; } Скриншот: применение:first-child, :last-child и:nth-child </p><p>Мы написали CSS стиль для дочерних элементов простого HTML-документа, где тег <div> является родителем для тегов <p> , <table> . Разберем CSS по порядку.</p> <p>Первое правило – p:first-child – касается элемента p: если он является <b>первым дочерним элементом своего родителя </b>, то к нему применяется стиль (в нашем случае это жирный шрифт и преобразование текста в верхний регистр). Если в данный HTML-код сразу после открывающего тега <div> добавить еще какой-нибудь тег (к примеру, <h2>), то стиль p:first-child уже не будет отображаться, поскольку <p>Перестанет быть первым дочерним тегом. В данном случае первым дочерним элементом будет h2 .</p> <p>Всё то же самое происходит и с правилом p:last-child – стиль CSS будет применен к тегу <p>Лишь тогда, когда он будет являться <b>последним дочерним элементом своего родителя </b>. Добавьте после <p>Любой другой тег отличного типа и вы увидите, что правило p:last-child перестанет применяться.</p> <p>Правило p:nth-child(3) работает для <b>третьего </b> дочернего тега <p> (об этом свидетельствует число 3 в скобках). Цвет шрифта для этого абзаца становится красным. Вы можете изменить число 3 (например, на 2) и посмотреть результат.</p> <p>Правила tr:nth-child(odd) и tr:nth-child(even) работают для нечётных и чётных элементов tr соответственно. Вы можете увидеть результат на скриншоте, а также скопировать весь код и поэкспериментировать со стилями самостоятельно.</p> <h4>Пример использования:first-of-type, :last-of-type, :nth-of-type и:only-of-type</h4> <!-- HTML --> <div> <h2>Первый ребенок</h2> <p>Второй ребенок</p> <p>Третий ребенок</p> <h3>Четвертый ребенок</h3> <p>Пятый ребенок</p> <h4>Последний ребенок</h4> </div> <p> /* CSS */ p:first-of-type { color: violet; text-transform: uppercase; } p:last-of-type { font-style: italic; font-size: 0.8em; } p:nth-of-type(3) { color: red; } p:nth-of-type(odd) { background-color: #A2DED0; } p:nth-of-type(even) { background-color: #C8F7C5; } h3:only-of-type { text-decoration: underline; } <br><img src='https://i2.wp.com/idg.net.ua/blog/wp-content/uploads/of-type-pseudo-classes.png' width="100%" loading=lazy> Скриншот: применение:first-of-type, :last-of-type, :nth-of-type и:only-of-type </p><p>Первое <a href="/pravila-css-oformlenie-tekstovyh-elementov-identifikatory-i-nazvaniya.html">правило CSS</a>, которое вы видите – это p:first-of-type . Что оно делает? Оно выбирает дочерний элемент типа p , который <b>первым </b> встречается у родителя. И не важно, на каком месте среди элементов других типов находится данный тег – на первом, втором или десятом. В этом и заключается отличие между псевдоклассами:first-child и:first-of-type .</p> <p>Второе правило – p:last-of-type – применяет стиль к <b>последнему </b> дочернему элементу типа p . Как видно из HTML-кода, после последнего тега <p>Есть еще и тег <h4> , присутствие которого никак не влияет на выполнение CSS-правила (в отличие от варианта с:last-of-child).</p> <p>Следующее правило – p:nth-of-type(3) – изменяет цвет шрифта на красный. Применяется этот стиль к тегу <p>Который является <b>третьим </b> по счету элементом своего типа у родителя. На скриншоте вы видите, что красный цвет применяется к тегу <p>Который по факту является пятым ребенком тега <div> . Но если не брать во внимание элементы других типов, то получается, что тег <p>С красным шрифтом находится на третьем месте (среди тегов своего типа). Таким образом работает данное правило.</p> <p>Правила p:nth-of-type(even) и p:nth-of-type(odd) работают аналогично: поскольку перед двоеточием указано имя p , то выбираются четные и нечетные дочерние элементы типа p и окрашиваются в заданные цвета. Остальные элементы пропускаются.</p> <p>Последнее правило – h3:only-of-type – применяется к содержимому тега <h3> , делая текст подчеркнутым. Данный стиль работает лишь потому, что тег <h3> является <b>единственным </b> дочерним элементом своего типа. Если в HTML-код добавить еще один тег <h3> , стиль не будет применён.</p> <h3>Выводы</h3> <p>Дочерний селектор CSS позволяет изменить стиль дочернего элемента HTML-документа, исходя из того, кто является его родителем.</p> <p>С помощью дополнительных псевдоклассов:first-child, :last-child, :nth-child, :only-child можно стилизовать дочерние элементы HTML-документа, ориентируясь на их местоположение, нумерацию в дереве элементов.</p> <p>Псевдоклассы:first-of-type, :last-of-type, :nth-of-type, :only-of-type позволяют применять стиль к дочерним элементам HTML-документа, ориентируясь на их тип, а также на нумерацию в дереве элементов.</p> <br> <br> <script>document.write("<img style='display:none;' src='//counter.yadro.ru/hit;artfast_after?t44.1;r"+ escape(document.referrer)+((typeof(screen)=="undefined")?"": ";s"+screen.width+"*"+screen.height+"*"+(screen.colorDepth? screen.colorDepth:screen.pixelDepth))+";u"+escape(document.URL)+";h"+escape(document.title.substring(0,150))+ ";"+Math.random()+ "border='0' width='1' height='1' loading=lazy>");</script> </div> <div id="fb-root"></div> <script> !function (d, id, did, st) { var js = d.createElement("script"); js.src = "https://connect.ok.ru/connect.js"; js.onload = js.onreadystatechange = function () { if (!this.readyState || this.readyState == "loaded" || this.readyState == "complete") { if (!this.executed) { this.executed = true; setTimeout(function () { OK.CONNECT.insertShareWidget(id,did,st); } , 0); } } }; d.documentElement.appendChild(js); } (document,"ok_shareWidget",document.URL,"{ width:100,height:30,st:'rounded',sz:20,nt:1} "); </script> <script>(function(d, s, id) { var js, fjs = d.getElementsByTagName(s)[0]; if (d.getElementById(id)) return; js = d.createElement(s); js.id = id; js.src = "//connect.facebook.net/ru_RU/sdk.js#xfbml=1&version=v2.5"; fjs.parentNode.insertBefore(js, fjs); } (document, 'script', 'facebook-jssdk')); </script> </article> </div> </section> </main> </div> <aside class="right-sidebar"> <div class="rightBox"> <div id="nav_menu-3" class="rightBoxMid widget_nav_menu"><div class="menu-pravoe-menyu-container"><ul id="menu-pravoe-menyu" class="menu"> <li class="menu-item menu-item-type-taxonomy menu-item-object-category"><a href="/category/tele2/">Теле2</a></li> <li class="menu-item menu-item-type-taxonomy menu-item-object-category"><a href="/category/beeline/">Билайн</a></li> <li class="menu-item menu-item-type-taxonomy menu-item-object-category"><a href="/category/rostelecom/">Ростелеком</a></li> <li class="menu-item menu-item-type-taxonomy menu-item-object-category"><a href="/category/tele2/">Tele2</a></li> <li class="menu-item menu-item-type-taxonomy menu-item-object-category"><a href="/category/mts/">Мтс</a></li> <li class="menu-item menu-item-type-taxonomy menu-item-object-category"><a href="/category/megaphone/">Мегафон</a></li> <li class="menu-item menu-item-type-taxonomy menu-item-object-category"><a href="/category/yota/">Yota</a></li> </ul></div></div> </div><div class="rightBox"> </div><div class="rightBox"> <div id="text-4" class="rightBoxMid widget_text"> <div class="textwidget"><div id="sahyvo1" style="height:400px;width:300px;" align="center"></div></div> </div> </div><div class="rightBox"> </div><div class="rightBox"> <div id="enhancedtextwidget-4" class="rightBoxMid widget_text enhanced-text-widget"><div class="textwidget widget-text"><div id="smartrotator_ad_119"></div> </div></div> </div> </aside> <div class="clear"></div> </div> </div> <footer> <div class="top"> <div class="block_width"> <a href="/" class="logo left"><img src="/uploads/logo.png" alt="Сотовая связь и телекоммуникации" loading=lazy></a> <div class="send right"> <div class="left"> <span class="title">Подписаться <br/> на обновления</span> <span class="small">Получайте уведомления <br/> о новостях</span> </div> <div class="form_block right"> <div class="Subscribers" id="Subscribers"> <div> <form class="es_widget_form" data-es_form_id="es_widget_form"> <div class="es_lablebox"><label class="es_widget_form_email">Email *</label></div> <div class="es_textbox"> <input type="text" id="es_txt_email" class="es_textbox_class" name="es_txt_email" onkeypress="if(event.keyCode==13) es_submit_page(event,'https://gnk86.ru')" value="" maxlength="225"> </div> <div class="es_button"> <input type="button" id="es_txt_button" class="es_textbox_button es_submit_button" name="es_txt_button" onClick="return es_submit_page(event,'https://gnk86.ru')" value="Subscribe"> </div> <div class="es_msg" id="es_widget_msg"> <span id="es_msg"></span> </div> <input type="hidden" id="es_txt_name" name="es_txt_name" value=""> <input type="hidden" id="es_txt_group" name="es_txt_group" value=""> </form> </div> </div> </div> </div> </div> </div> <div class="bottom1"> <div class="block_width"> <div class="link"> <div id="footerInner"> <div class="boxFooter"><div class="menu-futer-menyu-container"><ul id="menu-futer-menyu" class="menu"> <li class="menu-item type-post_type object-page "><a href="/feedback.html">Обратная связь</a></li> <li class="menu-item type-post_type object-page "><a href="">Реклама на сайте</a></li> <li class="menu-item type-post_type object-page "><a href="/sitemap.xml">Карта сайта</a></li> </ul></div></div> </div> </div> </div> </div> <div class="bottom2"> <div class="block_width"> <div class="copyright left"> <span>Copyright ©2024 gnk86.ru Сотовая связь и телекоммуникации</span> </div> <div class="counter right"></div> </div> </div> </footer> <link rel="stylesheet" href="//maxcdn.bootstrapcdn.com/font-awesome/4.3.0/css/font-awesome.min.css"> <script type="text/javascript"> $(function() { //We initially hide the all dropdown menus $('#dropdown_nav li').find('.sub-menu').hide(); //When hovering over the main nav link we find the dropdown menu to the corresponding link. $('#dropdown_nav li').hover(function() { //Find a child of 'this' with a class of .sub_nav and make the beauty fadeIn. $(this).find('.sub-menu').fadeIn(400); } , function() { //Do the same again, only fadeOut this time. $(this).find('.sub-menu').fadeOut(100); } ); } ); </script> <script type="text/javascript"> /* использование: <a class='scrollTop' href='#' style='display:none;'></a> ------------------------------------------------- */ $(function(){ var e = $(".scrollTop"); var speed = 5000; e.click(function(){ $("html:not(:animated)" +( !$.browser.opera ? ",body:not(:animated)" : "")).animate({ scrollTop: 0} , 2500 ); return false; //важно! } ); //появление function show_scrollTop(){ ( $(window).scrollTop()>300 ) ? e.fadeIn(300) : e.hide(); } $(window).scroll( function(){ show_scrollTop()} ); show_scrollTop(); } ); </script> <script type="text/javascript"> $(document).ready(function(e) { // мои скрипты $('aside #content4 .wp-polls a[title="Результаты голосования"]').text('Результат'); $('aside .menu > li a').click(function(e){ //e.preventDefault(); $('aside .menu > li a').removeClass('active'); $(this).addClass('active'); var submenu = $(this).next().css('display'); if($(this).next().css('display') == 'none'){ $(this).next('.sub-menu').fadeIn(300); } else { $(this).next('.sub-menu').fadeOut(300); } } ); $('footer .form_block input[type=text]').val('Введите Ваш e-mail...'); $('footer .form_block input[type=text]').focus(function(){ if($(this).val()=='Введите Ваш e-mail...'){ $(this).val(''); } } ); $('footer .form_block input[type=text]').blur(function(){ if($(this).val()==''){ $(this).val('Введите Ваш e-mail...'); } } ); $('.category_page .box-descr h2 span').text($('#archive-title span').text()); $('.menu_block .fa').click(function(){ $(this).next().fadeToggle(300); } ); // обрамление картинок в <span class="images clear"> var html = document.documentElement; if(html.clientWidth <=1024){ var block_img = $('.page_post .cont p img'); block_img.wrap('<span class="images clear"></span>'); } var span = $('.company_page.single_pages ol li'); span.html('<span>'+span.text()+'</span>'); $('.tab_module .tab_link span').click(function(){ $('.tab_module .tab_link span').removeClass('active'); $(this).addClass('active'); var data_href = $(this).attr('data-href'); var data_id = $('.tab_module .tab_block > div').attr('data-id'); //alert(data_id); $('.tab_module .tab_block > div').fadeOut(100); $('.tab_module .tab_block div[data-id='+data_href+']').fadeIn(500); } ); $('.menu_block #dropdown_nav div > ul > li').click(function(){ var l_link = $(this).children('a').attr('href'); //alert(l_link); location.href = l_link; } ); } ); </script> <script type="text/javascript" src="https://gnk86.ru/wp-content/themes/parazit/js/jquery.form.js"></script> <script type="text/javascript" src="//vk.com/js/api/openapi.js?116"></script> <script type="text/javascript">jQuery(function($) { $(document).on("click", ".pseudo-link", function(){ window.open($(this).data("uri")); } );} );</script><link rel='stylesheet' id='su-box-shortcodes-css' href='/wp-content/plugins/shortcodes-ultimate/assets/css/box-shortcodes.css?ver=5.0.1' type='text/css' media='all' /> <link rel='stylesheet' id='su-media-shortcodes-css' href='/wp-content/plugins/shortcodes-ultimate/assets/css/media-shortcodes.css?ver=5.0.1' type='text/css' media='all' /> <script type='text/javascript' src='https://gnk86.ru/wp-content/plugins/contact-form-7/includes/js/scripts.js?ver=4.9.2'></script> <script type='text/javascript'> /* <![CDATA[ */ var es_widget_notices = { "es_email_notice":"Please enter email address","es_incorrect_email":"Please provide a valid email address","es_load_more":"loading...","es_ajax_error":"Cannot create XMLHTTP instance","es_success_message":"Successfully Subscribed.","es_success_notice":"Your subscription was successful! Within a few minutes, kindly check the mail in your mailbox and confirm your subscription. If you can't see the mail in your mailbox, please check your spam folder.","es_email_exists":"Email Address already exists!","es_error":"Oops.. Unexpected error occurred.","es_invalid_email":"Invalid email address","es_try_later":"Please try after some time","es_problem_request":"There was a problem with the request"} ; /* ]]> */ </script> <script type='text/javascript' src='https://gnk86.ru/wp-content/plugins/email-subscribers/widget/es-widget.js?ver=f44a546683168d01506d837af1e42754'></script> <script type='text/javascript'> /* <![CDATA[ */ var es_widget_page_notices = { "es_email_notice":"Please enter email address","es_incorrect_email":"Please provide a valid email address","es_load_more":"loading...","es_ajax_error":"Cannot create XMLHTTP instance","es_success_message":"Successfully Subscribed.","es_success_notice":"Your subscription was successful! Within a few minutes, kindly check the mail in your mailbox and confirm your subscription. If you can't see the mail in your mailbox, please check your spam folder.","es_email_exists":"Email Address already exists!","es_error":"Oops.. Unexpected error occurred.","es_invalid_email":"Invalid email address","es_try_later":"Please try after some time","es_problem_request":"There was a problem with the request"} ; /* ]]> */ </script> <script type='text/javascript' src='https://gnk86.ru/wp-content/plugins/email-subscribers/widget/es-widget-page.js?ver=f44a546683168d01506d837af1e42754'></script> <script type='text/javascript' src='https://gnk86.ru/wp-content/plugins/supertoc/front.js?ver=1000'></script> <script type='text/javascript' src='https://gnk86.ru/wp-content/plugins/wp-polls/polls-js.js?ver=2.73.8'></script> <script type='text/javascript' src='https://gnk86.ru/wp-content/plugins/wp-postratings/js/postratings-js.js?ver=1.85'></script> <script type='text/javascript'> var q2w3_sidebar_options = new Array(); q2w3_sidebar_options[0] = { "sidebar" : "sidebar-1", "margin_top" : 10, "margin_bottom" : 0, "stop_id" : "", "screen_max_width" : 0, "screen_max_height" : 0, "width_inherit" : false, "refresh_interval" : 1500, "window_load_hook" : false, "disable_mo_api" : false, "widgets" : ['enhancedtextwidget-4'] } ; </script> <script type='text/javascript' src='https://gnk86.ru/wp-content/plugins/q2w3-fixed-widget/js/q2w3-fixed-widget.min.js?ver=5.0.4'></script> <script type='text/javascript' src='/wp-includes/js/wp-embed.min.js?ver=f44a546683168d01506d837af1e42754'></script> <script async="async" type='text/javascript' src='https://gnk86.ru/wp-content/plugins/akismet/_inc/form.js?ver=4.0.1'></script> <script type='text/javascript' src='https://gnk86.ru/wp-content/plugins/easy-fancybox/fancybox/jquery.fancybox-1.3.8.min.js?ver=1.6.2'></script> <script type='text/javascript' src='https://gnk86.ru/wp-content/plugins/easy-fancybox/js/jquery.easing.min.js?ver=1.4.0'></script> <script type='text/javascript' src='https://gnk86.ru/wp-content/plugins/easy-fancybox/js/jquery.mousewheel.min.js?ver=3.1.13'></script> <script type="text/javascript"> jQuery(document).on('ready post-load', function(){ jQuery('.nofancybox,a.pin-it-button,a[href*="pinterest.com/pin/create"]').addClass('nolightbox'); } ); jQuery(document).on('ready post-load',easy_fancybox_handler); jQuery(document).on('ready',easy_fancybox_auto);</script> </body> </html>