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

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

В своих публикациях я довольно подробно останавливался на различных видах CSS селекторов: ; а также . Кстати, в последней статье, где разбирались разные виды селектора атрибута, я довольно подробно описал, как мои теоретические выкладки можно тут же проверить, внося изменения в HTML и CSS код онлайн с помощью встроенного инструмента Google Chrome (). Такие средства редактирования имеют новейшие модификации всех популярных браузеров, включая плагин Firebug для Firefox ().

Теоретический материал этого поста вы можете также изучать, делая редактирование любой страницы любого сайта! Для этого просто нажмите F12, если пользуетесь Google Chrome или Mozilla Firefox (). А теперь представлю содержание тега p, на примере которого будем изучать дочерние и контекстные CSS селекторы :

Этот абзац включает теги форматирования em и strong, которые выделяют текст жирным и курсивом.

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


Эта HTML конструкция , . Этот параграф будет подопытным в сегодняшней публикации, на его примере я покажу, как меняется оформление его текста, в зависимости от того, какие селекторы - дочерние или контекстные - используются в правиле CSS.

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

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

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

Дочерний селектор в дереве элементов находится всегда непосредственно внутри родительского элемента, в этом случае синтаксис написания CSS селектора будет следующим:

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

P> em {color: green;}

Это правило будет влиять на последнее слово абзаца “курсивом”, поскольку именно оно заключено между открывающим и закрывающим тегами em. Тег em является дочерним для p, потому что размещается непосредственно внутри него, следовательно текст содержания, а именно слово “курсивом” будет окрашено в зеленый цвет.


Однако другое тег em не служит прямым потомком тега p, так как входит в состав тега strong, вследствии чего часть абзаца “теги форматирования em и strong” не будет окрашена.

Контекстный CSS селектор

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

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

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

P em {color: green;}


Как видите, зеленым окрашен не только текст части содержания абзаца, который непосредственно заключен в тег форматирования em, то есть слово “курсивом”, но и участок текста другого тега em, который входит еще и в состав тега strong. Это случилось потому, что действует правило с контекстным селектором, для которого не важен уровень вложенности в отличие от дочернего селектора. В этом и есть принципиальная разница дочернего и контекстного селектора.

Рассмотрим еще один пример взаимодействия контекстных и дочерних селекторов с нашим абзацем. Пропишем cледующие CSS правила для дочернего и контекстного селектора:

Div em {color: red;} p> em {color: green;}

После этого наш абзац приобретает такое оформление:


Как видите, кусок текста, заключенный в теги em и strong, выкрашен в красный цвет, потому что для него справедливо правило контекстного селектора, то есть тег em заключен в контейнеры strong и div, а уровень вложенности, как уже было отмечено, не имеет значения.

Возникает вопрос: почему же слово “курсивом”, тоже являющееся содержанием em, окрашено в зеленый цвет? Ведь и для него правило контекстного селектора является актуальным. Но для этого участка текста абзаца справедливо и правило дочернего селектора, потому что оно не противоречит тому условию, что для дочернего селектора элемент должен непосредственно входить в состав тега p.

Дело в том, в CSS действует закон приоритета для CSS свойств, находящихся ниже. То есть в данном случае правило дочернего селектора находится в документе ниже, чем CSS стили, прописанные для контекстного селектора контейнера div. Поэтому слово “курсивом” стало зеленым. Если поменять их местами, то правило «p> em {color: green;}» перестает действовать и участок текста “курсивом” будет красным.

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

Дочерним называется элемент, который непосредственно располагается внутри родительского элемента. Чтобы лучше понять отношения между элементами документа, разберём небольшой код (пример 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>Приветствую Вас, уважаемые читатели. В предыдущих статьях мы изучали, в основном, атрибуты стилей CSS. Их очень много. Одни задают параметры шрифтов, другие параметры фона, третьи параметры отступов и рамок.</p> <p>В этой статье мы поговорим о селекторах стилей. В одной из статье мы уже затрагивали . А сегодня рассмотрим еще несколько видов селекторов, которые не явно привязывают правило стиля к элементу веб-страницы. Это так называемые специальные селекторы. Их бывает несколько видов.</p> <h2>Комбинаторы в CSS (Соседний, дочерний и контекстный селекторы)</h2> <p><i>Комбинаторы </i> — это разновидность <a href="/routers/css-selektor-nachinaetsya-znachenie-atributa-okanchivaetsya-opredel-nnym-tekstom/">css селекторов</a>, привязывающие правило стиля к элементу web-страницы на основании его местоположения относительно других элементов.</p> <p>Первый комбинатор символ <b>плюс </b> (+) или <b>соседний селектор </b>. Плюс устанавливается между двумя селекторами:</p> <p><селектор 1> + <селектор 2> { <стиль> }</p> <p>Стиль в этом случае применяется к <i>селектору 2 </i>, но только в том случае если он является соседним для <i>селектора 1 </i> и идет сразу после него. Рассмотрим пример:</p> <p>strong + i {<br><br> }<br> ...<br> <p>Это <a href="/different/kak-vstavit-koncevuyu-snosku-redaktirovanie-teksta-v-obychnoi/">обычный текст</a>. <strong>Это <a href="/windows/osnovnye-html-tegi-formatirovaniya-teksta-vydelenie-teksta/">жирный текст</a></strong>, обычный текст, <i>красный текст</i> </p><br> <p>Это обычный текст. <strong>Это жирный текст</strong>, обычный текст, <i>и это обычный текст</i>.</p></p> <p>Результат:</p> <p>Стиль описанный в примере будет применен только к первому тексту заключенному в тег <i><i> </i>, т.к. он следует сразу же после тега <i><strong> </i>.</p> <p>Комбинатор <b>тильда </b> (~) также применяется к соседним селекторам, но в этот раз между ними могут быть другие элементы. При этом оба селектора должны быть вложены в один и тот же родительский тег:</p> <p><селектор 1> ~ <селектор 2> { <стиль> }</p> <p>Стиль будет применен к <i>селектору 2 </i>, который должен следовать за <i>селектором 1 </i>. Рассмотри пример:</p> <p>strong ~ i {<br> color: red; /* Красный цвет текста */<br> }<br> ...<br> <p>Это обычный текст. <strong>Это жирный текст</strong>, обычный текст, <i>красный текст</i> к нему применилось правило соседних селекторов.</p><br> <p>Это обычный текст. <strong>Это жирный текст</strong>, обычный текст, <i>а это красный текст</i>.</p></p> <p>Результат:</p> <p><img src='https://i0.wp.com/webcodius.ru/wp-content/uploads/2014/12/selektory2.png' align="center" width="100%" loading=lazy></p> <p>Как видим, в этот раз правило стиля сработало для обоих текстов заключенных в тег <i><i> </i>, несмотря на то, что во втором случае между тегом <i><strong> </i> и <i><i> </i> стоит тег <i><span> </i>.</p> <p>Комбинатор <b>> </b> относится к <b>дочерним селекторам </b>. Позволяет привязать стиль CSS к элементу веб-страницы, непосредственно вложенному в другой элемент:</p> <p><селектор 1> > <селектор 2> { <стиль> }</p> <p><i>Стиль </i> будет привязан к <i>селектору 2 </i>, который непосредственно вложен в <i>селектор 1 </i>.</p> <p>div > strong {<br><br> }<br> ...<br> <div>Это обычный текст. <strong>Это жирный курсивный текст </strong>.<br> <p>Это обычный текст. <strong>А это обычный жирный текст</strong>.</p><br> </div></p> <p>И результат:</p> <p><img src='https://i0.wp.com/webcodius.ru/wp-content/uploads/2014/12/selektory3.png' align="center" width="100%" loading=lazy></p> <p>Как видно на рисунке, правило стиля подействовало только на первый тег <i><strong> </i>, который непосредственно вложен в тег <i><div> </i>. А непосредственным родителем второго тега <i><strong> </i> является тег <i><p> </i>, поэтому правило на него не действует.</p> <p>Следующим рассмотрим <b>контекстный селектор <пробел> </b>. Он позволяет привязать CSS стиль к элементу вложенному в другой элемент, причем может быть любой уровень вложенности:</p> <p><селектор 1> <селектор 2> { <стиль> }</p> <p>Стиль будет применен к <i>селектору 2 </i>, если он так или иначе вложен в <i>селектор 1 </i>.</p> <p>Рассмотрим предыдущий пример, только при <a href="/modems/poyavlenie-bloka-pri-navedenii-css-urok-css-poyavlyayushcheesya-opisanie-pri-navedenie/">описании CSS</a> правила применим контекстный селектор:</p> <p>div strong {<br> font-style: italic /* Курсив */<br> }<br> ...<br> <div>Это обычный текст. <strong>Это жирный курсивный текст </strong>.<br> <p>Это обычный текст. <strong>А это тоже курсивный жирный текст</strong>.</p><br> </div><br> <p>Обычный текст и <strong>просто жирный текст</strong></p></p> <p>Результат:</p> <p><img src='https://i1.wp.com/webcodius.ru/wp-content/uploads/2014/12/selektory4.png' align="center" width="100%" loading=lazy></p> <p>Как видим, на этот раз правило подействовало на оба тега <i><strong> </i>, даже на тот, который вложен и в контейнер <i><div> </i> и в абзац <i><p> </i>. На тег <i><strong> </i>, который просто вложен в абзац <i><p> </i> <a href="/android/css-design-ukroshchenie-spiskov-pravila-css-dlya-nastroiki-vneshnego/">правило css</a> никак не действует.</p> <h2>Селекторы по атрибутам тега</h2> <p>Селекторы атрибутов — это специальные селекторы, которые привязывают стиль к элементу на основании, присутствует ли в нем определенный атрибут или имеет ли он определенное значение. Существует несколько вариантов применения таких селекторов.</p> <h3>1. Простой селектор атрибута</h3> <p>Имеет вид:</p> <p><селектор>[<имя атрибута тега>] { <стиль> }</p> <p>И привязывает стиль к тем элементам, внутри которых добавлен указанный атрибут. Например:</p> <p>strong{<br> color:red;<br> }<br> ...<br> <p><strong>Автомобиль</strong> это механическое моторное безрельсовое <strong title="<a href="/linux/perevod-kilometrov-v-chas-v-metry-v-sekundu-skorost-transportnyh/">транспортное средство</a>">дорожное транспортное средство</strong> минимум с 4 колёсами.</p></p> <p>Результат:</p> <p><img src='https://i1.wp.com/webcodius.ru/wp-content/uploads/2014/12/selektory5.png' align="center" width="100%" loading=lazy></p> <p>На рисунке можно заметить, что правило css (красный цвет текста) применяется к элементу <i>strong </i>, к которому добавлен атрибут <i>title </i>.</p> <h3>2. Селектор атрибута со значением</h3> <p>Синтаксис этого селектора следующий:</p> <p><селектор>[<имя атрибута тега>=<значение>] { <стиль> }</p> <p>Привязывает <i>стиль </i> к элементам, теги которых имеют атрибут с указанным <i>именем </i> и <i>значением </i>. Пример:</p> <p>a{<br> color:red;<br> font-size:150%;<br> }<br> ...<br>.ru" target="_blank">Ссылка в новом окне</a></p></p> <p>Результат:</p> <p><img src='https://i0.wp.com/webcodius.ru/wp-content/uploads/2014/12/selektory6.png' align="center" width="100%" loading=lazy></p> <p>Как видим, оба элемента типа гиперссылка имеют атрибут <i>target </i>, но правило css, которое увеличивает текст ссылки в полтора раза и изменяет его цвет в красный, применяется к тегу <i><a> </i> у которого атрибут <i>target </i> имеет значение <i>«_blank» </i>.</p> <h3>3. Одно из нескольких значений атрибута</h3> <p>Некоторые значения атрибутов могут перечисляться через пробел, например имена классов. Чтобы задать правило стиля при наличии в списке значений атрибутов требуемого значения применяется следующий селектор:</p> <p>[<имя атрибута тега>~=<значение>] { <стиль> }<br> <основной селектор>[<имя атрибута тега>~=<значение>] { <стиль> }</p> <p>Стиль применяется в том случае, если у атрибута имеется требуемое значение или оно входит в список значений, разделенных пробелами. Например:</p> <p>{<br> color:red;<br> font-size:150%;<br> }<br> ...<br> <p>Наш телефон: <span class="tel block">777-77-77</p><br> <p>Наш адрес: <span class="adress block">Москва ул. Советская 5</p></p> <p>Получиться следующий результат:</p> <p><img src='https://i1.wp.com/webcodius.ru/wp-content/uploads/2014/12/selektory7.png' align="center" width="100%" loading=lazy></p> <p>Правило применяется к элементу, у которого среди значений атрибута <i>class </i> имеется значение <i>tel </i>.</p> <h3>4. Дефис в значении атрибута</h3> <p>В значениях идентификаторов и классов допускается использовать дефис. Для привязки стиля к элементам, значения атрибутов которых могут содержать дефис можно воспользоваться следующей конструкцией:</p> <p>[атрибут|="значение"] { стиль }<br> Селектор[атрибут|="значение"] { стиль }</p> <p>Стиль применяется к тем элементам, у которых значение атрибута начинается с указанного значения после, которого идет дефис. Например:</p> <p>{<br> color:red;<br> font-size:150%;<br> }<br> ...<br> <ul><br> <li class="menu-item">Пункт 1</li><br> <li class="item-menu">Пункт 2</li><br> <li class="menuitem">Пункт 3</li><br> <li class="menu-item">Пункт 4</li><br> </ul></p> <p>Результат:</p> <p><img src='https://i2.wp.com/webcodius.ru/wp-content/uploads/2014/12/selektory8.png' align="center" width="100%" loading=lazy></p> <p>В примере правило стиля применяется только к тем элементам списка, у которых имя класса начинается со значения <i>«menu- „ </i>.</p> <h3>5. Значение атрибута начинается с определенного текста</h3> <p>Данный селектор устанавливает стиль для элемента, если значение атрибута тега начинается с определенного значения. Может быть два варианта:</p> <p>[<имя атрибута тега>^=<подстрока>] { <стиль> }<br> <основной селектор>[<имя атрибута тега>^=<подстрока>] { <стиль> }</p> <p>В первом случае <i>стиль </i> применяется ко всем элементам, теги которых имеют атрибут с указанным <i>именем </i> и значением, начинающимся с указанной <i>подстроки </i>. Во втором случае тоже самое, только к определенным элементам указанным в <i>основном селекторе </i>. Пример:</p> <p>a{<br> color:green;<br> font-weight:bold;<br> }<br> ...<br> </p> <p>Результат:</p> <p><img src='https://i0.wp.com/webcodius.ru/wp-content/uploads/2014/12/selektory9.png' align="center" width="100%" loading=lazy></p> <p>В примере показано, как по разному отобразить внешние ссылки и внутренние ссылки. Внешние ссылки всегда начинаются со строки «http://». Поэтому в селекторе указываем, что стиль применять только к ссылкам, у которых атрибут <i>href </i> начинается со значения <i>http:// </i>.</p> <h3>6. Значение атрибута заканчивается определенным текстом</h3> <p>Привязывает стиль к элементам, у которых значение атрибута заканчивается указанным текстом. Имеет следующий синтаксис:</p> <p>[<имя атрибута тега>$=<подстрока>] { <стиль> }<br> <основной селектор>[<имя атрибута тега>$=<подстрока>] { <стиль> }</p> <p>В первом случае <i>стиль </i> применяется ко всем элементам, у которых имеется <i>атрибут </i> с указанным <i>именем </i> и имеет значение оканчивающееся указанной <i>подстрокой </i>. Во втором случае тоже самое, только к указанным <i>селекторам </i>. Таким способом, например, можно по разному отображать различные форматы графических изображений. Например:</p> <p>IMG {<br> border: 5px solid red;<br> }<br> ...<br> <p>Картинка формата gif</p><br> <img src='https://i2.wp.com/1.gif' loading=lazy><br> <p>Картинка формата png</p><br> <img src='https://i0.wp.com/2.jpg' loading=lazy></p> <p>Результат:</p> <p><img src='https://i2.wp.com/webcodius.ru/wp-content/uploads/2014/12/selektory10.png' align="center" height="399" width="316" loading=lazy></p> <p>В примере все картинки с расширением gif будут отображаться с красной рамкой толщиной пять пикселей.</p> <h3>7. Значение атрибута содержит указанную строку</h3> <p>Этот селектор привязывает стиль к тегам, значение атрибута которых содержат определенный текст. Синтаксис:</p> <p>[<имя атрибута тега>*=<подстрока>] { <стиль> }<br> <основной селектор>[<имя атрибута тега>*=<подстрока>] { <стиль> }</p> <p><i>Стиль </i> привязывается к элементам, у которых имеется <i>атрибут </i> с указанным именем и его значение содержит указанную <i>подстроку </i>. Например:</p> <p>IMG {<br> border: 5px solid red;<br> }<br> ...<br> <p>Картинка из папки gallery</p><br> <img src='https://i2.wp.com/gallery/1.jpg' loading=lazy><br> <p>Картинка из другой папки</p><br> <img src='https://i0.wp.com/2.jpg' loading=lazy></p> <p>Результат:</p> <p><img src='https://i0.wp.com/webcodius.ru/wp-content/uploads/2014/12/selektory11.png' align="center" height="399" width="316" loading=lazy></p> <p>В примере стиль применяется к картинкам, которые загружены из папки <i>«gallery» </i>.</p> <p>На этом об селекторах атрибутов все. Все перечисленные методы можно комбинировать между собой:</p> <p>Селектор[атрибут1="значение1"][атрибут2="значение2"] { стиль }</p> <p>Кроме того напомню о специальных селекторах CSS:</p> <ul><li>с помощью символов «+» и «~» формируются ;</li> <li>символ «>» привязывает css стили к <b>дочерним </b> тегам;</li> <li>символ <пробел> формирует контекстные селекторы.</li> </ul><p>В следующих статьях мы рассмотрим также псевдоэлементы и псевдоклассы, которые предоставляют мощный инструмент управления стилями.</p> <p>На этом все, до новых встреч.</p> <p>Сложные и тяжелые веб-приложения стали обычными в наши дни. Кроссбраузерные и простые в использовании библиотеки типа jQuery с их широким функционалом могут сильно помочь в манипулировании DOM на лету. Поэтому неудивительно, что многие разработчики использую подобные библиотеки чаще, чем работают с нативным DOM API, с которым было немало проблем . И хотя различия в браузерах по-прежнему остаются проблемой, DOM находится сейчас в <a href="/modems/plaginy-obratnoi-svyazi-wordpress-bez-plagina-pyat-luchshih-plaginov-dlya-formy/">лучшей форме</a>, чем 5-6 лет назад , когда jQuery набирал популярность.</p> <p>В этой статье я продемонстрирую возможности DOM по манипулированию HTML, сфокусировавшись на отношения родительских, дочерних и соседних элементов. В заключении я дам данные о поддержке этих возможностей в браузерах, но учитывайте, что библиотека типа jQuery по-прежнему остается хорошей опцией в силу наличия багов и непоследовательностей в реализации нативного функционала.</p> <h2>Подсчет дочерних узлов</h2> <p>Для демонстрации я буду использовать следующую <a href="/internet/yazyk-gipertekstovoi-razmetki-html-naznachenie-yazyk-gipertekstovoi-razmetki-b/">разметку HTML</a>, в течение статьи мы ее несколько раз изменим:</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 . Это свойство только для чтения, оно возвращает коллекцию <a href="/different/pozicionirovanie-elementov-html-udalenie-prostranstva-mezhdu-strochno-blochnymi-elementami-unikalnoe/">элементов HTML</a>, находящихся внутри запрашиваемого элемента; для подсчета их количества я использую свойство 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 это коллекция всех узлов, включая пробелы - учитывайте это, если вам важна разница между дочерними узлами и <a href="/different/dochernie-selektory-v-css-tehniki-raboty-s-dom-roditelskie/">дочерними узлами-элементами</a>.</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 . Хотя список не содержит никаких элементов, в нем есть пробел, являющийся валидным типом узла. <a href="/windows/kak-razblokirovat-honor-6h-esli-zabyl-parol-metody-sbrosa-graficheskogo-klyucha/">Данный метод</a> учитывает все узлы, не только узлы-элементы. Чтобы 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>Но вместо вставки специально <a href="/modems/peretaskivanie-elementov-drag-and-drop-sozdaem-prostoi-html5-drag-drop-interfeis/">создаваемого элемента</a>, я также могу использовать 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>Этот метод не возвращает <a href="/solutions/pomehoustoichivost-radiokanala-svyazi-s-udalennymi-stacionarnymi-obektami/">удаленный объект</a> и не работает в IE (только в Edge). И оба метода удаляют текстовые узлы точно так же, как и узлы-элементы.</p> <h2>Замена дочерних элементов</h2> <p>Я могу заменить существующий дочерний элемент новым, независимо от того, существует ли этот <a href="/solutions/ponimanie-bootstrap-kak-eto-rabotaet-i-chto-novogo-klassy-poryadka/">новый элемент</a> или я создал его с нуля. Вот разметка:</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() принимает два аргумента: новый элемент и заменяемый им <a href="/smart-tv/css-centrirovanie-bloka-gorizontalnoe-i-vertikalnoe-vyravnivanie-elementov/">старый элемент</a>.</p> <p>Я также могу использовать это метод для перемещения существующего элемента. Взгляните на <a href="/wi-fi/kak-sdelat-perehod-na-sleduyushchuyu-stranicu-v-html-perenapravlenie-na-druguyu/">следующий HTML</a>:</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>Существует несколько <a href="/smart-tv/kak-vosstanovit-perepisku-v-vk-vse-rabochie-sposoby-sozdanie/">разных способов</a> выбора <a href="/computer/css-vtoroi-dochernii-element-dochernie-selektory-css-vyborka-konkretnyh-dochernih/">конкретного элемента</a>. Как показано ранее, я могу начать с использования коллекции 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. Давайте перейдем к <a href="/operating-systems/pohozhii-stati-po-odnoi-teme-plaginy-dlya-otobrazheniya-pohozhih-zapisei/">похожей теме</a> и взглянем на новые возможности по вставке контента.</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>Этот метод прост. Попробуем теперь более <a href="/android/razblokirovat-noutbuk-ot-virusa-samomu-virus-prosit-dengi-za/">мощный способ</a> вставки: метод 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> <div class="data"> <div class="data__top clearfix"> <div class="data__print"> <a href='javascript:window.print(); void 0;'> Печать</a> </div> </div> <div class="data__bottom clearfix"> <div class="data__share"> <script src="//yastatic.net/es5-shims/0.0.2/es5-shims.min.js"></script> <script src="//yastatic.net/share2/share.js"></script> <div class="ya-share2" data-services="vkontakte,facebook,odnoklassniki,moimir,gplus,twitter,evernote,whatsapp,skype"></div> </div> </div> </div> <div class="navi"> <a href="/computer/globalnye-mody-dlya-minecraft-1-12-luchshie-mody-dlya-minecraft/" class="navi__prev"></a> <!-- /next_post --> <a href="/smartphone/skachat-normalnye-mody-na-mainkraft-1-12-luchshie-mody-dlya-minecraft/" class="navi__next"></a> <!-- /next_post --> </div> </div> </div> <div class="news-blocks clearfix"> <div class="news-block"> <div class="papers"> <div class="papers__title">Также интересно:</div> <div class="papers__items"> <style> </style> <div class="papers__item"> <div class="papers__img"> <a href="/program/rukovodstvo-i-prohozhdenie-po-dark-sector-dark-sector-prohozhdenie-glava-viii-neestestvennaya/"><img src="/uploads/136439c3ebd3082e29c360163d104de5.jpg" style="width:70px; height:70px;" / loading=lazy></a> </div> <div class="papers__ovh"> <div class="papers__name"> <a href="/program/rukovodstvo-i-prohozhdenie-po-dark-sector-dark-sector-prohozhdenie-glava-viii-neestestvennaya/">Dark Sector: Прохождение Глава VIII: Неестественная история</a> </div> <div class="papers__category"> </div> </div> </div> <div class="papers__item"> <div class="papers__img"> <a href="/network/netu-diska-d-windows-7-chto-delat-esli-na-kompe-netu-diska-d-chto-delat-esli/"><img src="/uploads/257af101e8cad14c0a3aa90b944e4ed6.jpg" style="width:70px; height:70px;" / loading=lazy></a> </div> <div class="papers__ovh"> <div class="papers__name"> <a href="/network/netu-diska-d-windows-7-chto-delat-esli-na-kompe-netu-diska-d-chto-delat-esli/">Что делать если на компе нету диска D?</a> </div> <div class="papers__category"> </div> </div> </div> <div class="papers__item"> <div class="papers__img"> <a href="/program/kak-otkatit-ili-udalit-problemnoe-obnovlenie-windows-kak-otkatit-ili/"><img src="/uploads/b8eca33fcf9d2966c9981da1e6ae6ab8.jpg" style="width:70px; height:70px;" / loading=lazy></a> </div> <div class="papers__ovh"> <div class="papers__name"> <a href="/program/kak-otkatit-ili-udalit-problemnoe-obnovlenie-windows-kak-otkatit-ili/">Как откатить или удалить проблемное обновление Windows Откат к предыдущей сборке windows 10</a> </div> <div class="papers__category"> </div> </div> </div> </div> </div> </div> <div class="news-block"> <div class="papers"> <div class="papers__title">Рекомендуем почитать:</div> <div class="papers__items"> <div class="papers__item"> <div class="papers__img"> <a href="/program/ispolzovanie-union-v-sql-operator-dlya-raboty-s-naborami-union-obedinenie-zaprosov-union/"> <img width="50" height="50" src="/uploads/23f37f789e4ac8bf7a92c9fbcd87c250.jpg" class="attachment-50 size-50 wp-post-image" alt="Оператор для работы с наборами UNION Объединение запросов union" sizes="(max-width: 50px) 100vw, 50px" / loading=lazy> </a> </div> <div class="papers__ovh"> <div class="papers__date">2023-08-11 00:02:15</div> <div class="papers__name"> <a href="/program/ispolzovanie-union-v-sql-operator-dlya-raboty-s-naborami-union-obedinenie-zaprosov-union/">Оператор для работы с наборами UNION Объединение запросов union</a> </div> </div> </div> <div class="papers__item"> <div class="papers__img"> <a href="/smartphone/samye-bystrye-superkompyutery-mira-ibm-sozdala-samyi-moshchnyi-v-mire/"> <img width="50" height="50" src="/uploads/85672a4d86028b8c0e2a21c19730b8c3.jpg" class="attachment-50 size-50 wp-post-image" alt="IBM создала самый мощный в мире компьютер Топ 10 самых мощных компьютеров в мире" sizes="(max-width: 50px) 100vw, 50px" / loading=lazy> </a> </div> <div class="papers__ovh"> <div class="papers__date">2023-08-11 00:02:15</div> <div class="papers__name"> <a href="/smartphone/samye-bystrye-superkompyutery-mira-ibm-sozdala-samyi-moshchnyi-v-mire/">IBM создала самый мощный в мире компьютер Топ 10 самых мощных компьютеров в мире</a> </div> </div> </div> <div class="papers__item"> <div class="papers__img"> <a href="/smart-tv/podrobnyi-katalog-socialnyh-setei-my-znaem-daleko-ne-vse-kakie/"> <img width="50" height="50" src="/uploads/31660f485df52d43cbaca389172ae7c2.jpg" class="attachment-50 size-50 wp-post-image" alt="Мы знаем далеко не все: какие социальные сети существуют в интернете Путешествия и отдых" sizes="(max-width: 50px) 100vw, 50px" / loading=lazy> </a> </div> <div class="papers__ovh"> <div class="papers__date">2023-08-10 00:03:18</div> <div class="papers__name"> <a href="/smart-tv/podrobnyi-katalog-socialnyh-setei-my-znaem-daleko-ne-vse-kakie/">Мы знаем далеко не все: какие социальные сети существуют в интернете Путешествия и отдых</a> </div> </div> </div> </div> </div> </div> </div> <div class="rate clearfix"> <div class="papers__title">В продолжение темы:</div> </div> <div class="rate clearfix"> <div class="rate__img"> <a href="/windows/processory-intel-core-i3-i5-i-i7-v-chem-raznica-i-chto-luchshe-kompyutery-s-processorom-intel-i5-konf/"> <img width="150" height="150" src="/uploads/8618a6155c3f90f41e5d97949a925946.jpg" class="attachment-alm-thumbnail size-alm-thumbnail wp-post-image" alt="Компьютеры с процессором intel i5 Конфигурация тестовых стендов" sizes="(max-width: 150px) 100vw, 150px" / loading=lazy> </a> </div> <div class="rate__ovh"> <div class="rate__label"> <span>Windows</span> </div> <div class="rate__name"> <a href="/windows/processory-intel-core-i3-i5-i-i7-v-chem-raznica-i-chto-luchshe-kompyutery-s-processorom-intel-i5-konf/">Компьютеры с процессором intel i5 Конфигурация тестовых стендов</a> </div> <div class="rate__description"> <p>Часть вторая : "Важнейшие характеристики каждого семейства процессоров Intel Core i3/i5/i7. Какие из этих чипов представляют особый интерес" Введение Сначала мы приведём... </p> </div> </div> </div> <!-- /next_post --> </div> <div class="button-menu"></div> <div class="page__right"> <div class="menu"> <div class="menu__exit">×</div> <ul> <li><a href="/category/internet/" class="link-catalog">Интернет</a> </li> <li><a href="/category/program/" class="link-catalog">Программы</a> </li> <li><a href="/category/computer/" class="link-catalog">Компьютер</a> </li> <li><a href="/category/modems/" class="link-catalog">Модемы</a> </li> <li><a href="/category/smartphone/" class="link-catalog">Смартфон</a> </li> <li><a href="/category/network/" class="link-catalog">Сети</a> </li> <li><a href="/category/different/" class="link-catalog">Разное</a> </li> <li><a href="/category/wi-fi/" class="link-catalog">Wi-Fi</a> </li> </ul> </div> <div id="wywapo1" style="height:400px;width:290px;" align="center"></div> <div class="page__hidden-mobile"> <div class="papers"> <div class="papers__tabs"> <div class="active" data-eq="0">Новые статьи</div> <span>/</span> <div data-eq="1">Популярные</div> </div> <div class="papers__blocks"> <div class="papers__block active"> <div class="papers__items"> <div class="papers__item"> <div class="papers__img"> <a href="/smartphone/yandeks-temy-oformleniya-dlya-brauzera-temy-dlya-yandeks-brauzera/"> <img width="50" height="50" src="/uploads/1c8a1e1e7e8bf6430f3a7deaa3ddb9b8.jpg" class="attachment-50 size-50 wp-post-image" alt="Яндекс темы оформления для браузера" sizes="(max-width: 50px) 100vw, 50px" / loading=lazy> </a> </div> <div class="papers__ovh"> <div class="papers__date">2023-08-09 00:03:05</div> <div class="papers__name"> <a href="/smartphone/yandeks-temy-oformleniya-dlya-brauzera-temy-dlya-yandeks-brauzera/">Яндекс темы оформления для браузера</a> </div> <div class="papers__category"> <a href="/category/smartphone/">Смартфон</a> </div> </div> </div> <div class="papers__item"> <div class="papers__img"> <a href="/operating-systems/kak-ustanovit-standartnye-programmy-windows-7-perechen-standartnyh-programm/"> <img width="50" height="50" src="/uploads/e82dca906d3e62b572412374136d64f2.jpg" class="attachment-50 size-50 wp-post-image" alt="Перечень стандартных программ windows" sizes="(max-width: 50px) 100vw, 50px" / loading=lazy> </a> </div> <div class="papers__ovh"> <div class="papers__date">2023-08-09 00:03:05</div> <div class="papers__name"> <a href="/operating-systems/kak-ustanovit-standartnye-programmy-windows-7-perechen-standartnyh-programm/">Перечень стандартных программ windows</a> </div> <div class="papers__category"> <a href="/category/operating-systems/">Операционные системы</a> </div> </div> </div> <div class="papers__item"> <div class="papers__img"> <a href="/solutions/izmenenie-nastroek-kamery-likbez-ispolzuem-ruchnoi-rezhim-kamery-na/"> <img width="50" height="50" src="/uploads/401e58ce42f5a4178b54d839eedcfae6.jpg" class="attachment-50 size-50 wp-post-image" alt="Ликбез: используем ручной режим камеры на смартфоне Как установить фронтальной камеру по умолчанию" sizes="(max-width: 50px) 100vw, 50px" / loading=lazy> </a> </div> <div class="papers__ovh"> <div class="papers__date">2023-08-08 00:02:13</div> <div class="papers__name"> <a href="/solutions/izmenenie-nastroek-kamery-likbez-ispolzuem-ruchnoi-rezhim-kamery-na/">Ликбез: используем ручной режим камеры на смартфоне Как установить фронтальной камеру по умолчанию</a> </div> <div class="papers__category"> <a href="/category/solutions/">Решения</a> </div> </div> </div> <div class="papers__item"> <div class="papers__img"> <a href="/different/loshadki-kratkoe-opisanie-vozmozhnostei-kak-sdelat-bronyu-dlya/"> <img width="50" height="50" src="/uploads/843dbc243cb549f9d3701f2342b25976.jpg" class="attachment-50 size-50 wp-post-image" alt="Краткое описание возможностей" sizes="(max-width: 50px) 100vw, 50px" / loading=lazy> </a> </div> <div class="papers__ovh"> <div class="papers__date">2023-08-07 00:02:14</div> <div class="papers__name"> <a href="/different/loshadki-kratkoe-opisanie-vozmozhnostei-kak-sdelat-bronyu-dlya/">Краткое описание возможностей</a> </div> <div class="papers__category"> <a href="/category/different/">Разное</a> </div> </div> </div> <div class="papers__item"> <div class="papers__img"> <a href="/routers/otlichie-iphone-4s-evrotest-ot-rostest-raznica-mezhdu-rostest-i/"> <img width="50" height="50" src="/uploads/4ea68414f5812ecb4f2c5e6f79f72cfa.jpg" class="attachment-50 size-50 wp-post-image" alt="Разница между Ростест и Евротест сертификацией iPhone — что лучше?" sizes="(max-width: 50px) 100vw, 50px" / loading=lazy> </a> </div> <div class="papers__ovh"> <div class="papers__date">2023-08-06 00:02:04</div> <div class="papers__name"> <a href="/routers/otlichie-iphone-4s-evrotest-ot-rostest-raznica-mezhdu-rostest-i/">Разница между Ростест и Евротест сертификацией iPhone — что лучше?</a> </div> <div class="papers__category"> <a href="/category/routers/">Роутеры</a> </div> </div> </div> <div class="papers__item"> <div class="papers__img"> <a href="/modems/istoriya-sozdaniya-simvola-sobaka-kak-na-klaviature-nabrat/"> <img width="50" height="50" src="/uploads/e8a46ff6360727a5080cd3bc627a5cfe.jpg" class="attachment-50 size-50 wp-post-image" alt="Как на клавиатуре набрать «собаку» — три способа для ПК и ноутбука" sizes="(max-width: 50px) 100vw, 50px" / loading=lazy> </a> </div> <div class="papers__ovh"> <div class="papers__date">2023-08-05 00:04:02</div> <div class="papers__name"> <a href="/modems/istoriya-sozdaniya-simvola-sobaka-kak-na-klaviature-nabrat/">Как на клавиатуре набрать «собаку» — три способа для ПК и ноутбука</a> </div> <div class="papers__category"> <a href="/category/modems/">Модемы</a> </div> </div> </div> </div> </div> <div class="papers__block"> <div class="papers__items"> <div class="papers__item"> <div class="papers__img"><a href="/the-device/vidy-ftp-osobennosti-raboty-protokola-ftp-ustanovka-i-nastroika/"> <img width="50" height="50" src="/uploads/65cfdfbff821b547c614ff743ca92b38.jpg" class="attachment-50x50 size-50x50 wp-post-image" alt="Особенности работы протокола FTP" sizes="(max-width: 50px) 100vw, 50px" / loading=lazy> </a></div> <div class="papers__ovh"> <div class="papers__name"> <a href="/the-device/vidy-ftp-osobennosti-raboty-protokola-ftp-ustanovka-i-nastroika/">Особенности работы протокола FTP</a> </div> <div class="papers__category"><a href="/category/the-device/" rel="tag">Устройства</a></div> </div> </div> <div class="papers__item"> <div class="papers__img"><a href="/network/peers-tv---besplatnoe-onlain-tv-efir-i-arhiv-peers-tv-besplatnoe/"> <img width="50" height="50" src="/uploads/a5e32a75084f971e7423719f0ead1ff0.jpg" class="attachment-50x50 size-50x50 wp-post-image" alt="Peers TV – бесплатное онлайн ТВ на ПК Телевидение пирс" sizes="(max-width: 50px) 100vw, 50px" / loading=lazy> </a></div> <div class="papers__ovh"> <div class="papers__name"> <a href="/network/peers-tv---besplatnoe-onlain-tv-efir-i-arhiv-peers-tv-besplatnoe/">Peers TV – бесплатное онлайн ТВ на ПК Телевидение пирс</a> </div> <div class="papers__category"><a href="/category/network/" rel="tag">Сети</a></div> </div> </div> <div class="papers__item"> <div class="papers__img"><a href="/solutions/podklyuchit-dva-sistemnyh-bloka-kak-podklyuchit-dva-sistemnyh-bloka-k/"> <img width="50" height="50" src="/uploads/76933912a290f46058b94c3d8e688c3a.jpg" class="attachment-50x50 size-50x50 wp-post-image" alt="Как подключить два системных блока к одному монитору" sizes="(max-width: 50px) 100vw, 50px" / loading=lazy> </a></div> <div class="papers__ovh"> <div class="papers__name"> <a href="/solutions/podklyuchit-dva-sistemnyh-bloka-kak-podklyuchit-dva-sistemnyh-bloka-k/">Как подключить два системных блока к одному монитору</a> </div> <div class="papers__category"><a href="/category/solutions/" rel="tag">Решения</a></div> </div> </div> <div class="papers__item"> <div class="papers__img"><a href="/smartphone/import-i-eksport-kontaktov-iz-outlook-eksport-i-rezervnoe/"> <img width="50" height="50" src="/uploads/37104f16aaf5057b82ef11470a7de314.jpg" class="attachment-50x50 size-50x50 wp-post-image" alt="Экспорт и резервное копирование электронной почты, контактов и календаря в PST-файл Outlook Некоторые проблемы с письмами Outlook и их решение" sizes="(max-width: 50px) 100vw, 50px" / loading=lazy> </a></div> <div class="papers__ovh"> <div class="papers__name"> <a href="/smartphone/import-i-eksport-kontaktov-iz-outlook-eksport-i-rezervnoe/">Экспорт и резервное копирование электронной почты, контактов и календаря в PST-файл Outlook Некоторые проблемы с письмами Outlook и их решение</a> </div> <div class="papers__category"><a href="/category/smartphone/" rel="tag">Смартфон</a></div> </div> </div> <div class="papers__item"> <div class="papers__img"><a href="/smart-tv/ne-rabotaet-panel-windows-xp-pochemu-slomalas-elektroplita-ne-vklyuchaetsya/"> <img width="50" height="50" src="/uploads/f0c1fb3f6e2f75357edab060d0acb552.jpg" class="attachment-50x50 size-50x50 wp-post-image" alt="Почему сломалась электроплита" sizes="(max-width: 50px) 100vw, 50px" / loading=lazy> </a></div> <div class="papers__ovh"> <div class="papers__name"> <a href="/smart-tv/ne-rabotaet-panel-windows-xp-pochemu-slomalas-elektroplita-ne-vklyuchaetsya/">Почему сломалась электроплита</a> </div> <div class="papers__category"><a href="/category/smart-tv/" rel="tag">Smart TV</a></div> </div> </div> <div class="papers__item"> <div class="papers__img"><a href="/computer/globalnye-mody-dlya-minecraft-1-12-luchshie-mody-dlya-minecraft/"> <img width="50" height="50" src="/uploads/9421a49b47c52f2e9023a58084319d12.jpg" class="attachment-50x50 size-50x50 wp-post-image" alt="Глобальные моды для minecraft 1" sizes="(max-width: 50px) 100vw, 50px" / loading=lazy> </a></div> <div class="papers__ovh"> <div class="papers__name"> <a href="/computer/globalnye-mody-dlya-minecraft-1-12-luchshie-mody-dlya-minecraft/">Глобальные моды для minecraft 1</a> </div> <div class="papers__category"><a href="/category/computer/" rel="tag">Компьютер</a></div> </div> </div> </div> </div> </div> </div> <div class="comments"> <div id="wywapo2" class="wywapo-sticky" style="height:500px;width:254px;" align="center"></div> </div> </div> </div> </div> </div> </div> <div class="footer"> <div class="footer__top"> <div class="cnt"> <div class="footer__nav"> <ul> <li><a href="/feedback/">Контакты</a></li> <li><a href="">Реклама</a></li> <li><a href="">О сайте</a></li> </ul> </div> <div class="footer__counter"> </div> <div class="footer__logo1" align="right"> <img style="max-height:60px;" src="/uploads/logo.png" alt="" loading=lazy> </div> </div> </div> <div class="footer__bottom"> <div class="cnt"> <div class="footer__copyright"> © gikk.ru 2024 г. Гик - портал об интернете и компьютерной технике </div> </div> </div> </div> <a href="#top" class="up"></a> </div> <script src="https://gikk.ru/wp-content/themes/tehnika-expert/js/jquery-1.12.0.js"></script> <script src="https://gikk.ru/wp-content/themes/tehnika-expert/js/owl.carousel.min.js"></script> <script src="https://gikk.ru/wp-content/themes/tehnika-expert/js/mousewheel.js"></script> <script src="https://gikk.ru/wp-content/themes/tehnika-expert/js/jscrollpane.min.js"></script> <script src="https://gikk.ru/wp-content/themes/tehnika-expert/js/scripts.js?v=8"></script> <!--[if lt IE 10]> <script src="https://gikk.ru/wp-content/themes/tehnika-expert/js/placeholder.js"></script> <![endif]--> <script type='text/javascript' src='https://gikk.ru/wp-content/plugins/table-of-contents-plus/front.min.js?ver=1509'></script> <script type='text/javascript' src='https://gikk.ru/wp-content/plugins/wp-ajaxify-comments/js/wp-ajaxify-comments.min.js?ver=1.5.0'></script> <script type='text/javascript' src='https://gikk.ru/wp-content/plugins/wp-polls/polls-js.js?ver=2.73.8'></script> <script type='text/javascript' src='https://gikk.ru/wp-content/plugins/wp-postratings/js/postratings-js.js?ver=1.85'></script> <script type='text/javascript' src='https://gikk.ru/wp-content/plugins/wp_testme/js/testme.js?ver=1.1'></script> <script type='text/javascript' src='/wp-includes/js/comment-reply.min.js?ver=4.9'></script> <script type='text/javascript'> var q2w3_sidebar_options = new Array(); q2w3_sidebar_options[0] = { "sidebar" : "sidebar-2", "margin_top" : 10, "margin_bottom" : 112, "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" : ['cb_widget-2'] } ; </script> <script type='text/javascript' src='https://gikk.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.9'></script> </body> </html>