sonyps4.ru

Специальные селекторы в CSS. Соседние, дочерние, контекстные селекторы и селекторы по атрибуту тега

Приветствую Вас, уважаемые читатели. В предыдущих статьях мы изучали, в основном, атрибуты стилей CSS. Их очень много. Одни задают параметры шрифтов, другие параметры фона, третьи параметры отступов и рамок.

В этой статье мы поговорим о селекторах стилей. В одной из статье мы уже затрагивали . А сегодня рассмотрим еще несколько видов селекторов, которые не явно привязывают правило стиля к элементу веб-страницы. Это так называемые специальные селекторы. Их бывает несколько видов.

Комбинаторы в CSS (Соседний, дочерний и контекстный селекторы)

Комбинаторы — это разновидность css селекторов, привязывающие правило стиля к элементу web-страницы на основании его местоположения относительно других элементов.

Первый комбинатор символ плюс (+) или соседний селектор . Плюс устанавливается между двумя селекторами:

<селектор 1> + <селектор 2> { <стиль> }

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

strong + i {

}
...

Это обычный текст. Это жирный текст, обычный текст, красный текст


Это обычный текст. Это жирный текст, обычный текст, и это обычный текст.

Результат:

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

Комбинатор тильда (~) также применяется к соседним селекторам, но в этот раз между ними могут быть другие элементы. При этом оба селектора должны быть вложены в один и тот же родительский тег:

<селектор 1> ~ <селектор 2> { <стиль> }

Стиль будет применен к селектору 2 , который должен следовать за селектором 1 . Рассмотри пример:

strong ~ i {
color: red; /* Красный цвет текста */
}
...

Это обычный текст. Это жирный текст, обычный текст, красный текст к нему применилось правило соседних селекторов.


Это обычный текст. Это жирный текст, обычный текст, а это красный текст.

Результат:

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

Комбинатор > относится к дочерним селекторам . Позволяет привязать стиль CSS к элементу веб-страницы, непосредственно вложенному в другой элемент:

<селектор 1> > <селектор 2> { <стиль> }

Стиль будет привязан к селектору 2 , который непосредственно вложен в селектор 1 .

div > strong {

}
...

Это обычный текст. Это жирный курсивный текст .

Это обычный текст. А это обычный жирный текст.


И результат:

Как видно на рисунке, правило стиля подействовало только на первый тег , который непосредственно вложен в тег

. А непосредственным родителем второго тега является тег

, поэтому правило на него не действует.

Следующим рассмотрим контекстный селектор <пробел> . Он позволяет привязать CSS стиль к элементу вложенному в другой элемент, причем может быть любой уровень вложенности:

<селектор 1> <селектор 2> { <стиль> }

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

Рассмотрим предыдущий пример, только при описании CSS правила применим контекстный селектор:

div strong {
font-style: italic /* Курсив */
}
...

Это обычный текст. Это жирный курсивный текст .

Это обычный текст. А это тоже курсивный жирный текст.



Обычный текст и просто жирный текст

Результат:

Как видим, на этот раз правило подействовало на оба тега , даже на тот, который вложен и в контейнер

и в абзац

. На тег , который просто вложен в абзац

правило css никак не действует.

Селекторы по атрибутам тега

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

1. Простой селектор атрибута

Имеет вид:

<селектор>[<имя атрибута тега>] { <стиль> }

И привязывает стиль к тем элементам, внутри которых добавлен указанный атрибут. Например:

strong{
color:red;
}
...

Автомобиль это механическое моторное безрельсовое дорожное транспортное средство минимум с 4 колёсами.

Результат:

На рисунке можно заметить, что правило css (красный цвет текста) применяется к элементу strong , к которому добавлен атрибут title .

2. Селектор атрибута со значением

Синтаксис этого селектора следующий:

<селектор>[<имя атрибута тега>=<значение>] { <стиль> }

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

a{
color:red;
font-size:150%;
}
...
.ru" target="_blank">Ссылка в новом окне

Результат:

Как видим, оба элемента типа гиперссылка имеют атрибут target , но правило css, которое увеличивает текст ссылки в полтора раза и изменяет его цвет в красный, применяется к тегу у которого атрибут target имеет значение «_blank» .

3. Одно из нескольких значений атрибута

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

[<имя атрибута тега>~=<значение>] { <стиль> }
<основной селектор>[<имя атрибута тега>~=<значение>] { <стиль> }

Стиль применяется в том случае, если у атрибута имеется требуемое значение или оно входит в список значений, разделенных пробелами. Например:

{
color:red;
font-size:150%;
}
...

Наш телефон: 777-77-77


Наш адрес: Москва ул. Советская 5

Получиться следующий результат:

Правило применяется к элементу, у которого среди значений атрибута class имеется значение tel .

4. Дефис в значении атрибута

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

[атрибут|="значение"] { стиль }
Селектор[атрибут|="значение"] { стиль }

Стиль применяется к тем элементам, у которых значение атрибута начинается с указанного значения после, которого идет дефис. Например:

{
color:red;
font-size:150%;
}
...



  • Пункт 2



Результат:

В примере правило стиля применяется только к тем элементам списка, у которых имя класса начинается со значения «menu- „ .

5. Значение атрибута начинается с определенного текста

Данный селектор устанавливает стиль для элемента, если значение атрибута тега начинается с определенного значения. Может быть два варианта:

[<имя атрибута тега>^=<подстрока>] { <стиль> }
<основной селектор>[<имя атрибута тега>^=<подстрока>] { <стиль> }

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

a{
color:green;
font-weight:bold;
}
...

Результат:

В примере показано, как по разному отобразить внешние ссылки и внутренние ссылки. Внешние ссылки всегда начинаются со строки «http://». Поэтому в селекторе указываем, что стиль применять только к ссылкам, у которых атрибут href начинается со значения http:// .

6. Значение атрибута заканчивается определенным текстом

Привязывает стиль к элементам, у которых значение атрибута заканчивается указанным текстом. Имеет следующий синтаксис:

[<имя атрибута тега>$=<подстрока>] { <стиль> }
<основной селектор>[<имя атрибута тега>$=<подстрока>] { <стиль> }

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

IMG {
border: 5px solid red;
}
...

Картинка формата gif



Картинка формата png


Результат:

В примере все картинки с расширением gif будут отображаться с красной рамкой толщиной пять пикселей.

7. Значение атрибута содержит указанную строку

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

[<имя атрибута тега>*=<подстрока>] { <стиль> }
<основной селектор>[<имя атрибута тега>*=<подстрока>] { <стиль> }

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

IMG {
border: 5px solid red;
}
...

Картинка из папки gallery



Картинка из другой папки


Результат:

В примере стиль применяется к картинкам, которые загружены из папки «gallery» .

На этом об селекторах атрибутов все. Все перечисленные методы можно комбинировать между собой:

Селектор[атрибут1="значение1"][атрибут2="значение2"] { стиль }

Кроме того напомню о специальных селекторах CSS:

  • с помощью символов «+» и «~» формируются ;
  • символ «>» привязывает css стили к дочерним тегам;
  • символ <пробел> формирует контекстные селекторы.

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

На этом все, до новых встреч.

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

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

В предыдущей статье мы рассказывали о родственных связях между элементами HTML-документа, в том числе и о дочерних элементах. Давайте посмотрим на примере, как эти связи можно использовать в CSS.

Представьте, что вам нужно присвоить стиль только тем тегам

Которые являются дочерними по отношению к , не затрагивая остальные

(например,

Дочерние по отношению к

).
Как это сделать? Очень просто: создадим дочерний селектор:

Body > p { color: #333; }

Обратите внимание на символ > после body . С помощью него вы указываете, что стиль применяется исключительно для дочерних тегов

Родителя . Если символ убрать, то стиль применится абсолютно ко всем тегам

Которые находятся внутри тега , хотя они могут и не являться для него дочерними.

Дополнительные псевдоклассы

В CSS3 существует ряд псевдоклассов для работы с дочерними элементами. Ниже приведено описание каждого из них, примеры использования, а также отличия между псевдоклассами вида «child» и «of-type».

  • :first-child – с помощью этого псевдокласса можно применить стиль к указанному элементу веб-страницы, при условии, что он является первым
  • :last-child – стиль применяется к указанному элементу веб-страницы при условии, что он является последним дочерним элементом своего родителя;
  • :nth-child – позволяет выбрать четные (even) и нечетные (odd) дочерние элементы; также с помощью данного псевдокласса можно стилизовать чередующиеся дочерние элементы, используя выражения вида an+b и числа;
  • :only-child – применяется к дочернему элементу при условии, что тот является единственным ребенком у родителя;
  • :first-of-type – стиль применяется к первому элементу указанного типа (даже если этот элемент не является первым дочерним для своего родителя и над ним находятся другие дочерние элементы других типов);
  • :last-of-type – работает точно так же, как и предыдущий псевдокласс, с той лишь разницей, что стиль применяется к последнему элементу указанного типа ;
  • :nth-of-type – по принципу работы похож на:nth-child , но ориентируется на тип элемента;
  • :only-of-type – применяется к дочернему элементу указанного типа при условии, что тот является у родителя единственным ребенком своего типа .

Пример использования:first-child, :last-child и:nth-child

Первый ребенок

Второй ребенок

Третий ребенок

Нечетный номер
Четный номер
Нечетный номер
Четный номер

Последний ребенок

/* 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

Мы написали CSS стиль для дочерних элементов простого HTML-документа, где тег

является родителем для тегов

,

. Разберем CSS по порядку.

Первое правило – p:first-child – касается элемента p: если он является первым дочерним элементом своего родителя , то к нему применяется стиль (в нашем случае это жирный шрифт и преобразование текста в верхний регистр). Если в данный HTML-код сразу после открывающего тега

добавить еще какой-нибудь тег (к примеру,

), то стиль p:first-child уже не будет отображаться, поскольку

Перестанет быть первым дочерним тегом. В данном случае первым дочерним элементом будет h2 .

Всё то же самое происходит и с правилом p:last-child – стиль CSS будет применен к тегу

Лишь тогда, когда он будет являться последним дочерним элементом своего родителя . Добавьте после

Любой другой тег отличного типа и вы увидите, что правило p:last-child перестанет применяться.

Правило p:nth-child(3) работает для третьего дочернего тега

(об этом свидетельствует число 3 в скобках). Цвет шрифта для этого абзаца становится красным. Вы можете изменить число 3 (например, на 2) и посмотреть результат.

Правила tr:nth-child(odd) и tr:nth-child(even) работают для нечётных и чётных элементов tr соответственно. Вы можете увидеть результат на скриншоте, а также скопировать весь код и поэкспериментировать со стилями самостоятельно.

Пример использования:first-of-type, :last-of-type, :nth-of-type и:only-of-type

Первый ребенок

Второй ребенок

Третий ребенок

Четвертый ребенок

Пятый ребенок

Последний ребенок

/* 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; }
Скриншот: применение:first-of-type, :last-of-type, :nth-of-type и:only-of-type

Первое правило CSS, которое вы видите – это p:first-of-type . Что оно делает? Оно выбирает дочерний элемент типа p , который первым встречается у родителя. И не важно, на каком месте среди элементов других типов находится данный тег – на первом, втором или десятом. В этом и заключается отличие между псевдоклассами:first-child и:first-of-type .

Второе правило – p:last-of-type – применяет стиль к последнему дочернему элементу типа p . Как видно из HTML-кода, после последнего тега

Есть еще и тег

, присутствие которого никак не влияет на выполнение CSS-правила (в отличие от варианта с:last-of-child).

Следующее правило – p:nth-of-type(3) – изменяет цвет шрифта на красный. Применяется этот стиль к тегу

Который является третьим по счету элементом своего типа у родителя. На скриншоте вы видите, что красный цвет применяется к тегу

Который по факту является пятым ребенком тега

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

С красным шрифтом находится на третьем месте (среди тегов своего типа). Таким образом работает данное правило.

Правила p:nth-of-type(even) и p:nth-of-type(odd) работают аналогично: поскольку перед двоеточием указано имя p , то выбираются четные и нечетные дочерние элементы типа p и окрашиваются в заданные цвета. Остальные элементы пропускаются.

Последнее правило – h3:only-of-type – применяется к содержимому тега

, делая текст подчеркнутым. Данный стиль работает лишь потому, что тег

является единственным дочерним элементом своего типа. Если в HTML-код добавить еще один тег

, стиль не будет применён.

Выводы

Дочерний селектор CSS позволяет изменить стиль дочернего элемента HTML-документа, исходя из того, кто является его родителем.

С помощью дополнительных псевдоклассов:first-child, :last-child, :nth-child, :only-child можно стилизовать дочерние элементы HTML-документа, ориентируясь на их местоположение, нумерацию в дереве элементов.

Псевдоклассы:first-of-type, :last-of-type, :nth-of-type, :only-of-type позволяют применять стиль к дочерним элементам HTML-документа, ориентируясь на их тип, а также на нумерацию в дереве элементов.

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

Дочерним называется элемент, который непосредственно располагается внутри родительского элемента. Чтобы лучше понять отношения между элементами документа, разберём небольшой код (пример 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>Основная задача данного селектора следует из его названия и заключается в обращении к дочернему элементу. Выводится с помощью элементарного знака «>», который связывает дочерний элемент с элементом родителя. Также стоит отметить, что в обращении используется простые селекторы. В качестве примера рассмотрим следующую кодировку:</p> <p>Element > ul { padding- top: 20px; } </p> <p>Данная кодировка означает, что к списку, который вложен в element, будет применен внутренний отступ в 20 пикселей от верхнего края. Наличие в этой записи значка «>» показывает, что правило применится только к спискам первого уровня вложенности.</p> <h3>Подробный анализ работы селектора дочернего элемента</h3> <p>Селектор элемента дочернего имеет схожие свойства с понятием селектор потомка. Однако существует характерная черта, которая показывает принципиальное отличие данных операций. Оно заключается в том, что влияние селектора потомка распространяется на абсолютно все элементы, в то время как дочерний селектор подчиняет стили позиций первого уровня классификаций.</p> <p>Более наглядно оценить работу оператора дочернего селектора поможет следующий пример:</p> <p>Div > р { color: #ff0000; /* красный */ } </p> <p> < div> Данная строка будет иметь по умолчанию черный текст. < span> Эта строка перекраситься в красный в следствие того, что р является дочерним тегом для дива.</ span> < p> Опять видим черные буквы. < span> Здесь мы видим тоже черные символы, так как для этого спана родителем является тег р.</ span></ p> </ div> </p> <p>Данный пример подтверждает работу оператора дочернего селектора согласно степени вложенности.</p> <h3>Ограничение для применения оператора дочернего селектора</h3> <p>Стоит отметить, что данная операция поддерживается всеми браузерами кроме легендарного Internet Explorer 6. Думаю, мало кто использует данный браузер, однако же если таковые уникумы имеются, то для них существует выход из ситуации, который будет описан в отдельной статье.</p> <h3>Зачем применяется</h3> <p>Программеры обращаются к селекторам элементов дочерних в тех случаях, когда нужно присвоить свой уникальный стиль вложенным элементам. Также использование этого селектора может сократить объем CSS, что повысит читабельность документа. Как показывает практика, к этой операции обращаются чаще всего при создании выпадающих менюшек.</p> <p>Также селектор элемента дочернего используется для присвоения уникальных стилей элементам, родители которых уже известны за ранее. Другими словами:</p> <p>Main > header { <span>/* оформление относится только к главному хедеру */ </span> } </p> <p>Данный пример справедлив в тех случаях, когда тег header используют для выделения заголовков статей. В нашем случае мы задаем оформление только основному хедеру, и не задеваем второстепенные. Этот прием также позволяет избегать применения лишнего раза идентификаторов, что в свою очередь облегчает вес CSS-файла и делает его более читабельным.</p> <h3>Подводя итоги</h3> <p>Таким образом, оператор дочернего элемента можно применять не только для оформления выпадающих меню, но и для небольшой оптимизации вашего интернет ресурса к работе поисковых роботов.</p> <p>Сложные и тяжелые веб-приложения стали обычными в наши дни. Кроссбраузерные и простые в использовании библиотеки типа jQuery с их широким функционалом могут сильно помочь в манипулировании DOM на лету. Поэтому неудивительно, что многие разработчики использую подобные библиотеки чаще, чем работают с нативным DOM API, с которым было немало проблем . И хотя различия в браузерах по-прежнему остаются проблемой, DOM находится сейчас в лучшей форме, чем 5-6 лет назад , когда jQuery набирал популярность.</p> <p>В этой статье я продемонстрирую возможности DOM по манипулированию HTML, сфокусировавшись на отношения родительских, дочерних и соседних элементов. В заключении я дам данные о поддержке этих возможностей в браузерах, но учитывайте, что библиотека типа jQuery по-прежнему остается хорошей опцией в силу наличия багов и непоследовательностей в реализации нативного функционала.</p> <h2>Подсчет дочерних узлов</h2> <p>Для демонстрации я буду использовать следующую разметку HTML, в течение статьи мы ее несколько раз изменим:</p><p> <body> <ul id="myList"> <li>Example one</li> <li>Example two</li> <li>Example three</li> <li>Example four</li> <li>Example five</li> <li>Example Six</li> </ul> </body> </p><p>Var myList = document.getElementById("myList"); console.log(myList.children.length); // 6 console.log(myList.childElementCount); // 6 </p><p>Как видите, результаты одинаковые, хотя техники используются разные. В первом случае я использую свойство children . Это свойство только для чтения, оно возвращает коллекцию элементов HTML, находящихся внутри запрашиваемого элемента; для подсчета их количества я использую свойство length этой коллекции.</p> <p>Во втором примере я использую метод childElementCount , который мне кажется более аккуратным и потенциально более поддерживаемым способом (подробнее обсудим это позже, я не думаю, что у вас возникнут проблемы с пониманием того, что он делает).</p> <p>Я мог бы попытаться использовать childNodes.length (вместо children.length), но посмотрите на результат:</p><p>Var myList = document.getElementById("myList"); console.log(myList.childNodes.length); // 13 </p><p>Он возвращает 13, потому что childNodes это коллекция всех узлов, включая пробелы - учитывайте это, если вам важна разница между дочерними узлами и дочерними узлами-элементами.</p> <h2>Проверка существования дочерних узлов</h2> <p>Для проверки наличия у элемента дочерних узлов я могу использовать метод hasChildNodes() . Метод возвращает логическое значение, сообщающие об их наличии или отсутствии:</p><p>Var myList = document.getElementById("myList"); console.log(myList.hasChildNodes()); // true </p><p>Я знаю, что в моем списке есть дочерние узлы, но я могу изменить HTML так, чтобы их не было; теперь разметка выглядит так:</p><p> <body> </body> </p><p>И вот результат нового запуска hasChildNodes() :</p><p>Console.log(myList.hasChildNodes()); // true </p><p>Метод по прежнему возвращает true . Хотя список не содержит никаких элементов, в нем есть пробел, являющийся валидным типом узла. Данный метод учитывает все узлы, не только узлы-элементы. Чтобы hasChildNodes() вернул false нам надо еще раз изменить разметку:</p><p> <body> </body> </p><p>И теперь в консоль выводится ожидаемый результат:</p><p>Console.log(myList.hasChildNodes()); // false </p><p>Конечно, если я знаю, что могу столкнуться с пробелом, то сначала я проверю существование дочерних узлов, затем с помощью свойства nodeType определяю, есть ли среди них узлы-элементы.</p> <h2>Добавление и удаление дочерних элементов</h2> <p>Есть техника, которые можно использовать для добавления и удаления элементов из DOM. Наиболее известная из них основана на сочетании методов createElement() и appendChild() .</p><p>Var myEl = document.createElement("div"); document.body.appendChild(myEl); </p><p>В данном случае я создаю <div> с помощью метода createElement() и затем добавляю его к body . Очень просто и вы наверняка использовали эту технику раньше.</p> <p>Но вместо вставки специально создаваемого элемента, я также могу использовать appendChild() и просто переместить существующий элемент. Предположим, у нас следующая разметка:</p><p> <div id="c"> <ul id="myList"> <li>Example one</li> <li>Example two</li> <li>Example three</li> <li>Example four</li> <li>Example five</li> <li>Example Six</li> </ul> <p>Example text</p> </div> </p><p>Я могу изменить место расположения списка с помощью следующего кода:</p><p>Var myList = document.getElementById("myList"), container = document.getElementById("c"); container.appendChild(myList); </p><p>Итоговый DOM будет выглядеть следующим образом:</p><p> <div id="c"> <p>Example text</p> <ul id="myList"> <li>Example one</li> <li>Example two</li> <li>Example three</li> <li>Example four</li> <li>Example five</li> <li>Example Six</li> </ul> </div> </p><p>Обратите внимание, что весь список был удален со своего места (над параграфом) и затем вставлен после него перед закрывающим body . И хотя обычно метод appendChild() используется для добавления элементов созданных с помощью createElement() , он также может использоваться для перемещения существующих элементов.</p> <p>Я также могу полностью удалить дочерний элемент из DOM с помощью removeChild() . Вот как удаляется наш список из предыдущего примера:</p><p>Var myList = document.getElementById("myList"), container = document.getElementById("c"); container.removeChild(myList); </p><p>Теперь элемент удален. Метод removeChild() возвращает удаленный элемент и я могу его сохранить на случай, если он потребуется мне позже.</p><p>Var myOldChild = document.body.removeChild(myList); document.body.appendChild(myOldChild); </p><p>Таке существует метод ChildNode.remove() , относительно недавно добавленный в спецификацию:</p><p>Var myList = document.getElementById("myList"); myList.remove(); </p><p>Этот метод не возвращает удаленный объект и не работает в IE (только в Edge). И оба метода удаляют текстовые узлы точно так же, как и узлы-элементы.</p> <h2>Замена дочерних элементов</h2> <p>Я могу заменить существующий дочерний элемент новым, независимо от того, существует ли этот новый элемент или я создал его с нуля. Вот разметка:</p><p> <p id="par">Example Text</p> </p><p>Var myPar = document.getElementById("par"), myDiv = document.createElement("div"); myDiv.className = "example"; myDiv.appendChild(document.createTextNode("New element text")); document.body.replaceChild(myDiv, myPar); </p><p> <div class="example">New element text</div> </p><p>Как видите, метод replaceChild() принимает два аргумента: новый элемент и заменяемый им старый элемент.</p> <p>Я также могу использовать это метод для перемещения существующего элемента. Взгляните на следующий HTML:</p><p> <p id="par1">Example text 1</p> <p id="par2">Example text 2</p> <p id="par3">Example text 3</p> </p><p>Я могу заменить третий параграф первым параграфом с помощью следующего кода:</p><p>Var myPar1 = document.getElementById("par1"), myPar3 = document.getElementById("par3"); document.body.replaceChild(myPar1, myPar3); </p><p>Теперь сгенерированный DOM выглядит так:</p><p> <p id="par2">Example text 2</p> <p id="par1">Example text 1</p> </p><h2>Выборка конкретных дочерних элементов</h2> <p>Существует несколько разных способов выбора конкретного элемента. Как показано ранее, я могу начать с использования коллекции children или свойства childNodes . Но взглянем на другие варианты:</p> <p>Свойства firstElementChild и lastElementChild делают именно то, чего от них можно ожидать по их названию: выбирают первый и последний дочерние элементы. Вернемся к нашей разметке:</p><p> <body> <ul id="myList"> <li>Example one</li> <li>Example two</li> <li>Example three</li> <li>Example four</li> <li>Example five</li> <li>Example Six</li> </ul> </body> </p><p>Я могу выбрать первый и последний элементы с помощью этих свойств:</p><p>Var myList = document.getElementById("myList"); console.log(myList.firstElementChild.innerHTML); // "Example one" console.log(myList.lastElementChild.innerHTML); // "Example six" </p><p>Я также могу использовать свойства previousElementSibling и nextElementSibling , если я хочу выбрать дочерние элементы, отличные от первого или последнего. Это делается сочетанием свойств firstElementChild и lastElementChild:</p><p>Var myList = document.getElementById("myList"); console.log(myList.firstElementChild.nextElementSibling.innerHTML); // "Example two" console.log(myList.lastElementChild.previousElementSibling.innerHTML); // "Example five" </p><p>Также есть сходные свойства firstChild , lastChild , previousSibling , и nextSibling , но они учитывают все типы узлов, а не только элементы. Как правило, свойства, учитывающие только узлы-элементы полезнее тех, которые выбирают все узлы.</p> <h2>Вставка контента в DOM</h2> <p>Я уже рассматривал способы вставки элементов в DOM. Давайте перейдем к похожей теме и взглянем на новые возможности по вставке контента.</p> <p>Во-первых, есть простой метод insertBefore() , он во многом похож на replaceChild() , принимает два аргумента и при этом работает как с новыми элементами, так и с существующими. Вот разметка:</p><p> <div id="c"> <ul id="myList"> <li>Example one</li> <li>Example two</li> <li>Example three</li> <li>Example four</li> <li>Example five</li> <li>Example Six</li> </ul> <p id="par">Example Paragraph</p> </div> </p><p>Обратите внимание на параграф, я собираюсь сначала убрать его, а затем вставить перед списком, все одним махом:</p><p>Var myList = document.getElementById("myList"), container = document.getElementBy("c"), myPar = document.getElementById("par"); container.insertBefore(myPar, myList); </p><p>В полученном HTML параграф будет перед списком и это еще один способ перенести элемент.</p><p> <div id="c"> <p id="par">Example Paragraph</p> <ul id="myList"> <li>Example one</li> <li>Example two</li> <li>Example three</li> <li>Example four</li> <li>Example five</li> <li>Example Six</li> </ul> </div> </p><p>Как и replaceChild() , insertBefore() принимает два аргумента: добавляемый элемент и элемент, перед которым мы хотим его вставить.</p> <p>Этот метод прост. Попробуем теперь более мощный способ вставки: метод insertAdjacentHTML() .</p> <script type="text/javascript"> <!-- var _acic={dataProvider:10};(function(){var e=document.createElement("script");e.type="text/javascript";e.async=true;e.src="https://www.acint.net/aci.js";var t=document.getElementsByTagName("script")[0];t.parentNode.insertBefore(e,t)})() //--> </script><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> <nav class="gridlove-prev-next-nav"> <div class="gridlove-prev-link"> <a href="/kak-udalit-polnostyu-google-chrome-s-kompyutera-kak-polnostyu-udalit.html"> <span class="gridlove-pn-ico"><i class="fa fa fa-chevron-left"></i></span> <span class="gridlove-pn-link">Как полностью удалить Google Chrome с компьютера Как удалить гугл хром и установить новый</span> </a> <!-- /next_post --> </div> <div class="gridlove-next-link"> <a href="/kak-udalit-nenuzhnye-faily-s-diska-s-kak-udalyat-faily-s-diska-dvd-rw-instrukciya.html"> <span class="gridlove-pn-ico"><i class="fa fa fa-chevron-right"></i></span> <span class="gridlove-pn-link">Как удалять файлы с диска DVD-RW: инструкция Удалить файлы с cd диска</span> </a> <!-- /next_post --> </div> </nav> </div> </article> <div id="post-ratings-759-loading" class="post-ratings-loading"> <img src="https://sonyps4.ru/wp-content/plugins/wp-postratings/images/loading.gif" width="16" height="16" class="post-ratings-image" / loading=lazy> Загрузка...</div> <div class="gridlove-related"> <div class="gridlove-module"> <div class="module-header"><div class="module-title"><h4 class="h2">Возможно вам будет интересно:</h2></div></div> <div class="row"> <div class="col-lg-12 col-md-12 col-sm-12"> <article class="gridlove-post gridlove-post-b gridlove-box post-994478 post type-post status-publish format-standard has-post-thumbnail hentry category-sistema"> <div class="entry-image"> <a href="/sohranyaem-gotovoe-video-v-sony-vegas-bazovye-elementy-montazha-v-vegas-pro.html" title="Базовые элементы монтажа в Vegas Pro Вставка шаблонных титров"><img width="385" height="300" src="/uploads/9237b97746654f28a3eee980bc48ad42.jpg" class="attachment-gridlove-b8 size-gridlove-b8 wp-post-image" alt="Базовые элементы монтажа в Vegas Pro Вставка шаблонных титров" / loading=lazy></a> </div> <div class="box-inner-ptbr box-col-b entry-sm-overlay"> <div class="box-inner-ellipsis"> <div class="entry-category"> <a href="/category/question/" class="gridlove-cat gridlove-cat-28">Вопрос</a> </div> <h2 class="entry-title h3"><a href="/sohranyaem-gotovoe-video-v-sony-vegas-bazovye-elementy-montazha-v-vegas-pro.html">Базовые элементы монтажа в Vegas Pro Вставка шаблонных титров</a></h2> <div class="entry-content"> <p>Всем привет! Сегодня мы перейдем с вами к видеомонтажу. И первым делом мне хотелось бы дать вам подробную инструкцию, как пользоваться сони вегас про 13, даже если вы начинающий пользователь. На сегодняшний день эта программа является одной из лучших. Ко</p> </div> </div> <div class="entry-meta"> <div class="meta-item meta-author"><span class="vcard author"><span class="fn"> </span></span> </div> </div> </div> </article> </div> <div class="col-lg-12 col-md-12 col-sm-12"> <article class="gridlove-post gridlove-post-b gridlove-box post-994477 post type-post status-publish format-standard has-post-thumbnail hentry category-sistema"> <div class="entry-image"> <a href="/launcher-na-androide-chto-eto-takoe-kak-skachat-i-ustanovit-launcher-na-android.html" title="Как создать, установить и поменять тему на андроид Как создать лаунчер на все телефоны"><img width="385" height="300" src="/uploads/69c48aab164775811783ecd2295c819c.jpg" class="attachment-gridlove-b8 size-gridlove-b8 wp-post-image" alt="Как создать, установить и поменять тему на андроид Как создать лаунчер на все телефоны" / loading=lazy></a> </div> <div class="box-inner-ptbr box-col-b entry-sm-overlay"> <div class="box-inner-ellipsis"> <div class="entry-category"> <a href="/category/question/" class="gridlove-cat gridlove-cat-28">Вопрос</a> </div> <h2 class="entry-title h3"><a href="/launcher-na-androide-chto-eto-takoe-kak-skachat-i-ustanovit-launcher-na-android.html">Как создать, установить и поменять тему на андроид Как создать лаунчер на все телефоны</a></h2> <div class="entry-content"> <p>Для организации и взаимодействия с приложениями на Android используются лаунчеры. Которые обычно состоят из серии домашних экранов, где мы можем организовать ярлыки приложений, виджеты и так далее. Каждый телефон поставляется с лаунчером, но не все лаунче</p> </div> </div> <div class="entry-meta"> <div class="meta-item meta-author"><span class="vcard author"><span class="fn"> </span></span> </div> </div> </div> </article> </div> <div class="col-lg-12 col-md-12 col-sm-12"> <article class="gridlove-post gridlove-post-b gridlove-box post-994475 post type-post status-publish format-standard has-post-thumbnail hentry category-sistema"> <div class="entry-image"> <a href="/kakom-vide-hranyatsya-dannye-gde-i-v-kakom-vide-hranitsya-informaciya.html" title="Где и в каком виде хранится информация"><img width="385" height="300" src="/uploads/9c4bb5062f02199984af4fca5692ab83.jpg" class="attachment-gridlove-b8 size-gridlove-b8 wp-post-image" alt="Где и в каком виде хранится информация" / loading=lazy></a> </div> <div class="box-inner-ptbr box-col-b entry-sm-overlay"> <div class="box-inner-ellipsis"> <div class="entry-category"> <a href="/category/question/" class="gridlove-cat gridlove-cat-28">Вопрос</a> </div> <h2 class="entry-title h3"><a href="/kakom-vide-hranyatsya-dannye-gde-i-v-kakom-vide-hranitsya-informaciya.html">Где и в каком виде хранится информация</a></h2> <div class="entry-content"> <p>Откройте окно с задачей "Мой компьютер ". Если значки в окне мелкие, то измените их на крупные. Конечно, с помощью Правила Внешнего вида!Окно задачи будет выглядеть приблизительно так, как на рисунке:В данном примере значки (C:), (D:) и (E:) обозначают ло</p> </div> </div> <div class="entry-meta"> <div class="meta-item meta-author"><span class="vcard author"><span class="fn"> </span></span> </div> </div> </div> </article> </div> </div> </div> </div> </div> <div class="gridlove-sidebar"> <div class="gridlove-sticky-sidebar"> <div id="gridlove_category_widget-1" class="widget gridlove-box gridlove_category_widget"><h4 class="widget-title">Категории</h4> <ul class="gridlove-count-color"> <li><a href="/category/new-items/" class="gridlove-cat-col-3"><span class="category-text">Новинки</span></a></li> <li><a href="/category/question/" class="gridlove-cat-col-3"><span class="category-text">Вопрос</span></a></li> <li><a href="/category/help/" class="gridlove-cat-col-3"><span class="category-text">Помощь</span></a></li> <li><a href="/category/article/" class="gridlove-cat-col-3"><span class="category-text">Статья</span></a></li> <li><a href="/category/news/" class="gridlove-cat-col-3"><span class="category-text">Новости</span></a></li> <li><a href="/category/application/" class="gridlove-cat-col-3"><span class="category-text">Приложения</span></a></li> <li><a href="/category/comparison/" class="gridlove-cat-col-3"><span class="category-text">Сравнения</span></a></li> </ul> </div><div id="gridlove_posts_widget-1" class="widget gridlove-box gridlove_posts_widget"><h4 class="widget-title">Последние статьи<span class="gridlove-slider-controls"></span></h4> <div class="gridlove-posts-widget gridlove-widget-slider"> <div class="gridlove-posts-widget-item-wrapper"> <article class="post-983546 post type-post status-publish format-standard has-post-thumbnail hentry category-reviews"> <div class="entry-image"> <a href="/kak-sdelat-vremya-v-telefone-kak-nastroit-ili-pomenyat-datu-i-vremya-na-android.html" title="Как настроить или поменять дату и время на Android: установка вручную или автосинхронизация"> <img width="80" height="60" src="/uploads/7e86f460e3514916a184ba55ca15edab.jpg" class="attachment-gridlove-thumbnail size-gridlove-thumbnail wp-post-image" alt="Как настроить или поменять дату и время на Android: установка вручную или автосинхронизация" / loading=lazy> </a> </div> <div class="entry-header"> <h6><a href="/kak-sdelat-vremya-v-telefone-kak-nastroit-ili-pomenyat-datu-i-vremya-na-android.html">Как настроить или поменять дату и время на Android: установка вручную или автосинхронизация</a></h6> </div> </article> <article class="post-983545 post type-post status-publish format-standard has-post-thumbnail hentry category-reviews"> <div class="entry-image"> <a href="/kak-obnovit-vremya-na-telefone-kak-nastroit-datu-i-vremya-na-android-kak-vybrat.html" title="Как настроить дату и время на Android"> <img width="80" height="60" src="/uploads/382b99bd2347bdbfdfec6bfe55d0dfd2.jpg" class="attachment-gridlove-thumbnail size-gridlove-thumbnail wp-post-image" alt="Как настроить дату и время на Android" / loading=lazy> </a> </div> <div class="entry-header"> <h6><a href="/kak-obnovit-vremya-na-telefone-kak-nastroit-datu-i-vremya-na-android-kak-vybrat.html">Как настроить дату и время на Android</a></h6> </div> </article> <article class="post-983544 post type-post status-publish format-standard has-post-thumbnail hentry category-reviews"> <div class="entry-image"> <a href="/net-dostupa-papke-vindovs-10-kak-vosstanovit-dostup-k-papke-sposoby-resheniya.html" title="Как восстановить доступ к папке"> <img width="80" height="60" src="/uploads/4a2b38dc67574866fb299ee4efe169ed.jpg" class="attachment-gridlove-thumbnail size-gridlove-thumbnail wp-post-image" alt="Как восстановить доступ к папке" / loading=lazy> </a> </div> <div class="entry-header"> <h6><a href="/net-dostupa-papke-vindovs-10-kak-vosstanovit-dostup-k-papke-sposoby-resheniya.html">Как восстановить доступ к папке</a></h6> </div> </article> <article class="post-983543 post type-post status-publish format-standard has-post-thumbnail hentry category-reviews"> <div class="entry-image"> <a href="/osnovnyi-komandy-serverov-komandy-minecraft-servera-mainkraft-bez.html" title="Команды Minecraft Сервера Майнкрафт без регистрации"> <img width="80" height="60" src="/uploads/5d4f43860bee1123ca72f718a441547f.jpg" class="attachment-gridlove-thumbnail size-gridlove-thumbnail wp-post-image" alt="Команды Minecraft Сервера Майнкрафт без регистрации" / loading=lazy> </a> </div> <div class="entry-header"> <h6><a href="/osnovnyi-komandy-serverov-komandy-minecraft-servera-mainkraft-bez.html">Команды Minecraft Сервера Майнкрафт без регистрации</a></h6> </div> </article> <article class="post-983541 post type-post status-publish format-standard has-post-thumbnail hentry category-reviews"> <div class="entry-image"> <a href="/kak-skachat-vkontakte-na-telefon-vkontakte-dlya-android-poslednyaya.html" title="Вконтакте для андроид Последняя версия vk для андроид"> <img width="80" height="60" src="/uploads/53a5a8f1c134b329d30e29f09b28cff4.jpg" class="attachment-gridlove-thumbnail size-gridlove-thumbnail wp-post-image" alt="Вконтакте для андроид Последняя версия vk для андроид" / loading=lazy> </a> </div> <div class="entry-header"> <h6><a href="/kak-skachat-vkontakte-na-telefon-vkontakte-dlya-android-poslednyaya.html">Вконтакте для андроид Последняя версия vk для андроид</a></h6> </div> </article> </div> <div class="gridlove-posts-widget-item-wrapper"> <article class="post-983540 post type-post status-publish format-standard has-post-thumbnail hentry category-sistema"> <div class="entry-image"> <a href="/lozhnyi-vyzov---shutochnaya-programma-dlya-android-skachat-lozhnyi-vyzov.html" title="Скачать Ложный вызов на андроид v"> <img width="80" height="60" src="/uploads/e51718a0aa1d902ddb8d09f325276cf7.jpg" class="attachment-gridlove-thumbnail size-gridlove-thumbnail wp-post-image" alt="Скачать Ложный вызов на андроид v" / loading=lazy> </a> </div> <div class="entry-header"> <h6><a href="/lozhnyi-vyzov---shutochnaya-programma-dlya-android-skachat-lozhnyi-vyzov.html">Скачать Ложный вызов на андроид v</a></h6> </div> </article> <article class="post-983536 post type-post status-publish format-standard has-post-thumbnail hentry category-sistema"> <div class="entry-image"> <a href="/kak-perezagruzit-samsung-galaxy-esli-on-zavis-kak-vyklyuchit-samsung-on-zavis-kak.html" title="Как выключить самсунг он завис"> <img width="80" height="60" src="/uploads/68ddb89e70e9875665251c1549fe0801.jpg" class="attachment-gridlove-thumbnail size-gridlove-thumbnail wp-post-image" alt="Как выключить самсунг он завис" / loading=lazy> </a> </div> <div class="entry-header"> <h6><a href="/kak-perezagruzit-samsung-galaxy-esli-on-zavis-kak-vyklyuchit-samsung-on-zavis-kak.html">Как выключить самсунг он завис</a></h6> </div> </article> <article class="post-983535 post type-post status-publish format-standard has-post-thumbnail hentry category-sistema"> <div class="entry-image"> <a href="/podrobnyi-obzor-mobilnogo-telefona-samsung-s8500-wave-podrobnyi-obzor.html" title="Подробный обзор мобильного телефона Samsung S8500 Wave Самсунг wave s8500 cdma поддерживает"> <img width="80" height="60" src="/uploads/4d65de05088487c7d7bfcdd5e8479055.jpg" class="attachment-gridlove-thumbnail size-gridlove-thumbnail wp-post-image" alt="Подробный обзор мобильного телефона Samsung S8500 Wave Самсунг wave s8500 cdma поддерживает" / loading=lazy> </a> </div> <div class="entry-header"> <h6><a href="/podrobnyi-obzor-mobilnogo-telefona-samsung-s8500-wave-podrobnyi-obzor.html">Подробный обзор мобильного телефона Samsung S8500 Wave Самсунг wave s8500 cdma поддерживает</a></h6> </div> </article> <article class="post-983534 post type-post status-publish format-standard has-post-thumbnail hentry category-sistema"> <div class="entry-image"> <a href="/v-roznice-otmechaetsya-spros-na-novye-smartfony-prodazhi-galaxy-s8-v-rossii.html" title="Продажи Galaxy S8 в России вдвое выше, чем у предыдущего флагмана Samsung Телефон начинается с дизайна"> <img width="80" height="60" src="/uploads/b4105ca23891ce36a5fc75973817eba9.jpg" class="attachment-gridlove-thumbnail size-gridlove-thumbnail wp-post-image" alt="Продажи Galaxy S8 в России вдвое выше, чем у предыдущего флагмана Samsung Телефон начинается с дизайна" / loading=lazy> </a> </div> <div class="entry-header"> <h6><a href="/v-roznice-otmechaetsya-spros-na-novye-smartfony-prodazhi-galaxy-s8-v-rossii.html">Продажи Galaxy S8 в России вдвое выше, чем у предыдущего флагмана Samsung Телефон начинается с дизайна</a></h6> </div> </article> </div> </div> </div><div id="text-10" class="widget gridlove-box widget_text"> <h4 class="widget-title">Реклама</h4> <div class="textwidget"> </div> </div> </div> </div> </div> </div> <div id="footer" class="gridlove-footer"> <div class="container"> <div class="row"> <div class="col-lg-12 col-md-12 col-sm-12"> <div id="text-6" class="widget widget_text"> <div class="textwidget"> <p> </p> </div> </div> </div> </div> </div> <div class="gridlove-copyright"> <div class="container"> <p style="text-align: center">Copyright © 2024 </div> </div> </div> <div class="gridlove-sidebar-action-wrapper"> <span class="gridlove-action-close"><i class="fa fa-times" aria-hidden="true"></i></span> <div class="gridlove-sidebar-action-inside"> <div class="hidden-lg-up widget gridlove-box widget_nav_menu"> <ul id="menu-glavnoe-2" class="gridlove-mobile-menu"> <li class="menu-item menu-item-type-custom menu-item-object-custom current-menu-item current_page_item menu-item-home menu-item-"><a href="/category/new-items/">Новинки</a></li> <li class="menu-item menu-item-type-custom menu-item-object-custom current-menu-item current_page_item menu-item-home menu-item-"><a href="/category/question/">Вопрос</a></li> <li class="menu-item menu-item-type-custom menu-item-object-custom current-menu-item current_page_item menu-item-home menu-item-"><a href="/category/help/">Помощь</a></li> <li class="menu-item menu-item-type-custom menu-item-object-custom current-menu-item current_page_item menu-item-home menu-item-"><a href="/category/article/">Статья</a></li> <li class="menu-item menu-item-type-custom menu-item-object-custom current-menu-item current_page_item menu-item-home menu-item-"><a href="/category/news/">Новости</a></li> </ul> </div> </div> </div> <div class="gridlove-sidebar-action-overlay"></div> <script type='text/javascript' src='https://sonyps4.ru/wp-content/plugins/contact-form-7/includes/js/scripts.js?ver=4.9.2'></script> <script type='text/javascript' src='https://sonyps4.ru/wp-content/plugins/wp-postratings/js/postratings-js.js?ver=1.85'></script> <script type='text/javascript' src='/wp-includes/js/comment-reply.min.js?ver=4.7.8'></script> <script type='text/javascript'> /* <![CDATA[ */ var gridlove_js_settings = { "rtl_mode": "", "header_sticky": "1", "header_sticky_offset": "100", "header_sticky_up": "", "logo": "/logo/logo.png", "logo_retina": "/logo/logo.png", "logo_mini": "/logo/logo.png", "logo_mini_retina": "/logo/logo.png" }; /* ]]> */ </script> <script type='text/javascript' src='https://sonyps4.ru/wp-content/themes/gridlove/assets/js/min.js?ver=1.1'></script> <script type='text/javascript'> var q2w3_sidebar_options = new Array(); q2w3_sidebar_options[0] = { "sidebar" : "gridlove_default_sticky_sidebar", "margin_top" : 99, "margin_bottom" : 0, "stop_id" : "", "screen_max_width" : 1000, "screen_max_height" : 1280, "width_inherit" : true, "refresh_interval" : 12, "window_load_hook" : false, "disable_mo_api" : false, "widgets" : ['text-10'] } ; </script> <script type='text/javascript' src='https://sonyps4.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=4.7.8'></script> </body> </html>