Элемент iFrame уже много лет остаётся одной из ключевых технологий для встраивания внешнего контента на веб-страницы. Он позволяет отображать внутри сайта независимую страницу или приложение, фактически создавая автономное окно, которое существует отдельно от основного DOM. Такая изоляция делает iFrame удобным инструментом для интеграции сервисов, не требующих глубокого взаимодействия с сайтом-хостом. Несмотря на активное развитие API-интеграций, web-компонентов и других современных техник, iFrame продолжает широко использоваться благодаря своей универсальности, простоте внедрения, кроссбраузерной стабильности.
Определение и назначение
iFrame (inline frame) — это HTML-элемент, позволяющий встроить одну веб-страницу в другую, при этом обеспечивая четкое разграничение контентных областей. Он загружает внешний документ в собственный изолированный контекст браузера, что делает его своеобразной «песочницей» для размещения стороннего функционала.
Базовый пример синтаксиса:
Этот элемент остается незаменимым для разработчиков, которым нужно быстро внедрить внешний функционал без сложных интеграций. В отличие от <embed> или <object>, iFrame обладает более стабильной структурой отображения и гибкими настройками поведения.
С его помощью можно решать задачи разной сложности — от простого встраивания видео до размещения целых внешних приложений. Именно поэтому iFrame до сих пор широко используется в маркетинге, аналитике, e-commerce, обучающих платформах и корпоративных системах.
Применение iFrame
Область применения iFrame чрезвычайно широкая, особенно в ситуациях, когда требуется встроить сторонний контент, не адаптируя его под стилистику или архитектуру сайта. Такой подход позволяет сохранить неизменным внешний вид и поведение внешнего ресурса, что особенно важно при работе с сервисами, которые должны выглядеть и функционировать одинаково на всех площадках. Благодаря изоляции фрейма и отсутствию конфликтов с хост-страницей, iFrame остается удобным инструментом для размещения готовых решений.
Встраивание мультимедиа
iFrame стал стандартным способом размещения видеоплееров, презентаций, прямых трансляций и других медиаформатов. Платформы вроде YouTube, Vimeo, Rutube и образовательные сервисы используют именно этот подход, поскольку он обеспечивает стабильную работу плеера, защиту контента, независимость от стилей сайта. Такое решение позволяет сохранять полный контроль над воспроизведением, рекламными вставками, субтитрами и статистикой просмотров, не перегружая основной проект лишним функционалом.
Интерактивные карты
Современные картографические сервисы предоставляют готовые embed-виджеты, идеально работающие именно в iFrame. Благодаря этому сайты могут легко отображать схемы проезда, геолокацию, панорамы улиц, маршруты и геоданные без необходимости подключать сложные API. Такой подход особенно выгоден небольшим проектам, которым не нужна собственная логика работы карты: достаточно вставить код, настроить размер фрейма.
Внедрение сторонних сервисов
Через iFrame можно встроить практически любой сервис, интерфейс которого должен сохраняться полностью:
- формы бронирования;
- CRM-виджеты для записи или обработки заявок;
- платежные системы и кнопки;
- окна онлайн-консультантов;
- интерактивные калькуляторы, тесты.
Поставщикам услуг удобно предоставлять именно формат iFrame, так как он гарантирует, что их продукт будет отображаться одинаково на всех сайтах, а внутренние стили, скрипты не вступят в конфликт с кодом площадки.
Вывод независимого или потенциально опасного контента
В ситуациях, когда требуется показать стороннюю страницу, содержащую нестабильный код, экспериментальную функциональность или административную панель, iFrame обеспечивает надежную изоляцию. Он создаёт отдельный контекст выполнения, не позволяя внешнему скрипту вмешиваться в работу основного сайта. Это делает фрейм удобным инструментом для тестирования, интеграции мониторинговых панелей или размещения контента, который может нарушить структуру основной страницы.
Безопасность iFrame
iFrame часто рассматривается как потенциально опасный инструмент, если используется неправильно. Он действительно может создавать уязвимости, но современные стандарты позволяют значительно снизить риски.
Основные угрозы
Кликджекинг
Кликджекинг — одна из самых известных атак, связанных с iFrame. Ее суть заключается в том, что злоумышленник незаметно встраивает чужой сайт в прозрачный или маскированный iFrame и накладывает поверх него собственные элементы интерфейса. Пользователь думает, что нажимает на безопасную кнопку, но на самом деле совершает действие на реальном сайте — подтверждает покупку, изменяет настройки или передает данные. Именно из-за этого многие крупные сервисы намеренно запрещают отображение своих страниц во фреймах, минимизируя риск подобной подмены действий.
XSS через внешние фреймы
Если iFrame загружает непроверенный или потенциально опасный ресурс, внутри него может выполняться вредоносный JavaScript. В некоторых случаях такой скрипт способен попытаться взаимодействовать с родительской страницей, особенно если защита настроена неправильно. Это создает риск XSS-атак, фишинга, изменения DOM, перехвата данных пользователя. Проблема усиливается, когда фреймы используются без ограничений или разработчики доверяют внешним источникам без анализа безопасности.
Манипуляции с навигацией
Некорректно сконфигурированные iFrame могут изменять поведение браузера, перенаправлять пользователя на поддельные ресурсы или даже открывать всплывающие окна без его ведома. В прошлом такие атаки активно применялись мошенниками, чтобы уводить пользователей на фишинговые страницы или показывать рекламные баннеры. Именно поэтому защитные механизмы против таких действий были ужесточены на уровне браузеров, серверных настроек.
Механизмы защиты
sandbox
Атрибут sandbox — один из самых эффективных способов защитить родительскую страницу от потенциально опасного содержимого во фрейме. Он создаёт строго ограниченную среду, где действия внешнего сайта контролируются, блокируются по умолчанию.
Если не указывать дополнительные разрешения:
-
скрипты не смогут выполняться,
-
формы не будут отправляться,
-
клики по ссылкам не приведут к переходам,
-
доступ к большинству API браузера будет заблокирован.
Такой подход делает iFrame почти полностью безопасным, позволяет использовать его даже с незнакомым внешним контентом.
Content Security Policy (CSP)
CSP даёт разработчику возможность контролировать, какие внешние ресурсы могут загружаться внутри сайта, его фреймов. С помощью директивы frame-src можно явно определить список доверенных доменов.
Это позволяет исключить загрузку непроверенных источников, предотвращает XSS-атаки и делает поведение iFrame предсказуемым. CSP — один из самых современных и гибких инструментов защиты.
X-Frame-Options
Несмотря на то что этот механизм считается устаревшим, многие сайты по-прежнему используют его как дополнительный уровень защиты.
Заголовок:
запрещает встраивание страницы в iFrame на других доменах. Это гарантирует, что злоумышленник не сможет открыть страницу на чужом сайте и использовать её для кликджекинга или скрытой подмены действий пользователя.
SEO и iFrame
Поисковые системы относятся к содержимому, встроенному через iFrame, с большой осторожностью, это стоит учитывать при планировании SEO-стратегии. Для поисковиков iFrame чаще всего воспринимается как отдельный внешний элемент, не связанный напрямую с основным сайтом. Поэтому рассчитывать на то, что встроенный через него контент улучшит видимость ресурса в поиске, не приходится.
Почему iFrame плохо влияет на продвижение:
-
Контент внутри iFrame не считается частью вашего сайта. Поисковые алгоритмы считают его принадлежащим исходному домену, а не странице, на которой он отображается.
-
Он не индексируется как собственный текст. Даже если внутри фрейма находится большая информационная статья, поисковики не учитывают её для ранжирования хоста — это всегда внешний ресурс.
-
Поисковые роботы могут полностью игнорировать содержимое фрейма, особенно если домен не разрешает индексирование или использует защитные заголовки.
-
Ссылки внутри iFrame не передают ссылочный вес. Это значит, что любые внешние ссылки, встроенные через фрейм, не учитываются в ссылочном профиле сайта и не помогают продвижению.
По этим причинам iFrame категорически не подходит для размещения важных текстов, SEO-статей, лендингов и другого контента, который должен участвовать в ранжировании. Использование фреймов для таких целей приведёт к потере позиций, снижению эффективности продвижения.
Тем не менее, для встраивания медиа, карт, платежных модулей, форм обратной связи, интерактивных сервисов iFrame остаётся полностью безопасным. Он не влияет на SEO в негативную сторону, поскольку такие элементы не предназначены для индексации и служат исключительно для улучшения функционала, удобства сайта.
Примеры использования iFrame
YouTube
Встраивание видео через YouTube стало стандартом благодаря удобству, универсальности iFrame. Такой способ позволяет разместить ролик на странице буквально за несколько секунд, без настройки дополнительных скриптов или модулей. Плеер автоматически подстраивается под размер контейнера, поддерживает разные форматы воспроизведения и остается полностью управляемым со стороны YouTube, что избавляет разработчиков от проблем с совместимостью, обновлениями.
Преимущества:
- быстрое внедрение даже для начинающих пользователей;
- автоматическая адаптация под размер экрана, тип устройства;
- официальный интерфейс с кнопками, настройками качества, подписями.
Google Maps
Встраивание карт Google Maps через iFrame идеально подходит для сайтов, которым нужно показать посетителям локацию, маршруты или контактные данные компании. Такой вариант не требует настройки API и работает стабильно на всех устройствах. Он отлично подходит для страниц с адресами, профилей организаций, лендингов услуг, навигационных указателей.
Сторонние формы и сервисы
Через iFrame можно встроить практически любые инструменты, требующие сохранения оригинального дизайна и поведения:
- платежные виджеты;
- квизы, интерактивные анкеты;
- калькуляторы стоимости;
- формы записи или заявок;
- онлайн-чат или службу поддержки.
Такой подход особенно удобен, когда сервисы предоставляют готовый embed-код. Это позволяет подключить функционал за минуты, без полноценной интеграции с API и сложной логики. Кроме того, iFrame изолирует внешний сервис от сайта, что повышает стабильность, предотвращает конфликты стилей, скриптов.
Альтернативы и современные подходы
Несмотря на то что iFrame остаётся простым, универсальным и надежным инструментом, веб-разработка активно движется вперед, предлагая более гибкие и высокопроизводительные решения. Эти подходы позволяют избежать ограничений фреймов, ускорить загрузку страниц и повысить уровень безопасности при интеграции внешнего функционала.
API-интеграции
API используют в тех случаях, когда требуется внедрить не готовый интерфейс, а только данные или логику. Такой метод позволяет максимально органично встроить функционал в структуру сайта, сохранив единый дизайн, поведение и UX.
Преимущества API-интеграции:
- динамический контент подгружается через JavaScript, что делает обновления незаметными, быстрыми;
- сайт сохраняет собственную визуальную стилистику, контроль над разметкой;
- это наиболее SEO-дружественный вариант, так как весь контент попадает в индекс поисковых систем;
- архитектура остаётся гибкой, безопасной, легко масштабируемой.
API — лучший выбор для сложных сервисов, систем с постоянными обновлениями, интерфейсов с высокой вариативностью и крупных проектов.
Web Components (Shadow DOM)
Технология Web Components позволяет создавать собственные элементы HTML, полностью изолированные от остальной разметки. Используя Shadow DOM, разработчики могут защищать стили и структуру компонента от влияния внешнего CSS и JavaScript.
Преимущества:
- полная защита от конфликтов CSS, глобальных стилей;
- модульность интерфейса, что упрощает поддержку, повторное использование компонентов;
- высокая скорость работы за счёт нативной поддержки браузерами;
- возможность создавать масштабируемые systems design-библиотеки.
Фактически Web Components становятся «iFrame нового поколения», сохраняя изоляцию, но предлагая гораздо более плавную интеграцию, контроль.
Скриптовые виджеты
Многие сервисы создают embed-коды на основе обычного:
При подключении такого скрипта мини-приложение рендерится прямо внутри страницы, но без использования iFrame. Это экономит ресурсы и позволяет детальнее контролировать внешний вид, поведение виджета.
Преимущества скриптовых виджетов:
- высокая производительность;
- отсутствие лишней изоляции;
- гибкость интеграции;
- легкость обновления функционала поставщиком.
Тренды и развитие
Современные технологии активно меняют подход к использованию iFrame. Хотя фреймы продолжают оставаться полезным инструментом, их роль постепенно сдвигается в сторону более специализированных и ограниченных сценариев.
iFrame в SPA
В одностраничных приложениях (SPA) iFrame применяется точечно, в основном как:
- внешняя часть микросервиса,
- безопасная среда для платёжных форм,
- временная зона для подключения нестандартных интеграций.
За счёт изоляции он помогает соблюдать требования безопасности и защищать ключевые части приложения.
Ограничение сторонних ресурсов
Рост внимания к приватности, безопасности данных повлиял на работу iFrame:
- cookies внутри iFrame всё чаще становятся недоступными из-за строгих правил браузеров;
- для некоторых сценариев требуется явное согласие пользователя;
- многие сторонние ресурсы блокируются, если не соответствуют политикам безопасности.
Это усложняет внедрение старых решений, но делает веб-среду безопаснее, предсказуемее.
Рост микрофронтендов
Современные компании все чаще переходят на архитектуру микрофронтендов. Интерфейс собирается из независимых модулей, каждый из которых может быть создан и обновлён отдельной командой. В некоторых случаях такие модули изолируются внутри iFrame, чтобы:
- избежать конфликтов стилей,
- обеспечить устойчивую работу,
- разделить ответственность между командами.
Такой подход помогает масштабировать большие проекты, упрощает управление сложными интерфейсами.
Заключение
iFrame — это простая и надежная технология, которая остается актуальной несмотря на быстрый рост современных веб-решений. Он позволяет быстро внедрять внешний функционал, обеспечивать изоляцию, интегрировать сложные сервисы без переписывания кода. Однако использование iFrame требует понимания его ограничений — прежде всего в вопросах безопасности и SEO.
Сегодня iFrame часто применяется в связке с API, web-компонентами и SPA-архитектурой, дополняя новые подходы, обеспечивая удобную интеграцию сторонних интерфейсов.
<!DOCTYPE html>
<html class="h-100" data-bs-theme="light" data-mantine-color-scheme="light" lang="ru" prefix="og: https://ogp.me/ns#">
<head>
<meta content="width=device-width, initial-scale=1.0" name="viewport">
<meta content="IE=Edge" http-equiv="X-UA-Compatible">
<link crossorigin="true" href="https://cdn.hexlet.io" rel="preconnect">
<link href="https://mc.yandex.ru" rel="preconnect">
<meta content="aa2vrdtq64dub8knuf83lwywit311w" name="facebook-domain-verification">
<link href="/favicon.ico" rel="icon" sizes="any">
<link href="/favicon.svg" rel="icon" type="image/svg+xml">
<link href="/apple-touch-icon.png" rel="apple-touch-icon">
<link href="/manifest.webmanifest" rel="manifest">
<script>
//<![CDATA[
window.gon={};gon.ym_counter="25559621";gon.is_bot=true;gon.applications={};gon.current_user={"id":null,"last_viewed_notification_id":null,"email":null,"state":null,"first_name":"","last_name":"","created_at":"2026-02-26 23:07:06 UTC","current_program":null,"current_team":null,"full_name":"","guest":true,"can_use_paid_features":false,"is_hexlet_employee":false,"sanitized_phone_number":"","can_subscribe":true,"can_renew_education":false};gon.token="tmb70w9gN-KqUGeQYN_qIFm6ADul_dlI3F_GgZvNRq5ZtzDk_R6aghwTQwhs0BpXmbMtka3KJ-phv1zVycqhwA";gon.locale="ru";gon.language="ru";gon.theme="light";gon.rails_env="production";gon.mobile=false;gon.google={"analytics_key":"UA-1360700-51","optimize_key":"GTM-5QDVFPF"};gon.captcha={"google_v3_site_key":"6LenGbgZAAAAAM7HbrDbn5JlizCSzPcS767c9vaY","yandex_site_key":"ysc1_Vyob5ZPPUdPBsu0ykt8bVFdzsfpoVjQChLGl2b4g19647a89","verification_failed":null};gon.social_signin=false;gon.typoreporter_google_form_id="1FAIpQLSeibfGq-KvWQ2Fyru-zkFFRVTLBuzXAHAoEyN1p49FtDmNoNA";
//]]>
</script>
<meta charset="utf-8">
<title>Что такое iFrame? — Q&A Хекслет</title>
<meta name="description" content="2 ответа на вопрос, что такое iFrame простыми словами? Глоссарий Хекслета.">
<link rel="canonical" href="https://ru.hexlet.io/qna/glossary/questions/chto-takoe-iframe">
<meta property="og:description" content="2 ответа
на вопрос, что такое iFrame простыми словами? Глоссарий Хекслета.">
<meta property="og:title" content="Что такое iFrame? — Q&A Хекслет">
<meta property="og:url" content="https://ru.hexlet.io/qna/glossary/questions/chto-takoe-iframe">
<meta name="csrf-param" content="authenticity_token" />
<meta name="csrf-token" content="VtHdJ25yvU2Gfxu0aFEBBWhrznacWL6viQSzK8TcMsK5ABYQnAwQLTA8PyxkXvFyqGLj3JRvQA005Cl_ltvVrA" />
<script src="/vite/assets/inertia-DfXos102.js" crossorigin="anonymous" type="module"></script><link rel="modulepreload" href="/vite/assets/chunk-DsPFFUou.js" as="script" crossorigin="anonymous">
<link rel="modulepreload" href="/vite/assets/preload-helper-BJ4cLWpC.js" as="script" crossorigin="anonymous">
<link rel="modulepreload" href="/vite/assets/init-BrRXra1y.js" as="script" crossorigin="anonymous">
<link rel="modulepreload" href="/vite/assets/ahoy-DrlRQ-1D.js" as="script" crossorigin="anonymous">
<link rel="modulepreload" href="/vite/assets/analytics-cb8xch9l.js" as="script" crossorigin="anonymous">
<link rel="modulepreload" href="/vite/assets/ErrorFallbackBlock-naDSYSy9.js" as="script" crossorigin="anonymous">
<link rel="modulepreload" href="/vite/assets/Surface-DL2bpZA-.js" as="script" crossorigin="anonymous">
<link rel="modulepreload" href="/vite/assets/gon-D3e4yh1x.js" as="script" crossorigin="anonymous">
<link rel="modulepreload" href="/vite/assets/mantine-CGMYrt2Y.js" as="script" crossorigin="anonymous">
<link rel="modulepreload" href="/vite/assets/utils-DRqSHbQE.js" as="script" crossorigin="anonymous">
<link rel="modulepreload" href="/vite/assets/routes-CCH8ilKF.js" as="script" crossorigin="anonymous">
<link rel="modulepreload" href="/vite/assets/extends-C-EagtpE.js" as="script" crossorigin="anonymous">
<link rel="modulepreload" href="/vite/assets/inheritsLoose-BBd-DCVI.js" as="script" crossorigin="anonymous">
<link rel="modulepreload" href="/vite/assets/objectWithoutPropertiesLoose-DRHXDhjp.js" as="script" crossorigin="anonymous">
<link rel="modulepreload" href="/vite/assets/index.esm-DAqKOkZ0.js" as="script" crossorigin="anonymous">
<link rel="modulepreload" href="/vite/assets/Button-CGPUux8l.js" as="script" crossorigin="anonymous">
<link rel="modulepreload" href="/vite/assets/CloseButton-D1euiPao.js" as="script" crossorigin="anonymous">
<link rel="modulepreload" href="/vite/assets/Group-BX48WcuU.js" as="script" crossorigin="anonymous">
<link rel="modulepreload" href="/vite/assets/Loader-BQEY8g6v.js" as="script" crossorigin="anonymous">
<link rel="modulepreload" href="/vite/assets/Modal-Cy3HByv7.js" as="script" crossorigin="anonymous">
<link rel="modulepreload" href="/vite/assets/OptionalPortal-1Hza5P2w.js" as="script" crossorigin="anonymous">
<link rel="modulepreload" href="/vite/assets/Stack-CtjJzfw4.js" as="script" crossorigin="anonymous">
<link rel="modulepreload" href="/vite/assets/Textarea-Ck64llAy.js" as="script" crossorigin="anonymous">
<link rel="modulepreload" href="/vite/assets/Box-B5-OOzBf.js" as="script" crossorigin="anonymous">
<link rel="modulepreload" href="/vite/assets/DirectionProvider-Dc9zdUke.js" as="script" crossorigin="anonymous">
<link rel="modulepreload" href="/vite/assets/events-DJQOhap0.js" as="script" crossorigin="anonymous">
<link rel="modulepreload" href="/vite/assets/use-reduced-motion-D2owz4wa.js" as="script" crossorigin="anonymous">
<link rel="modulepreload" href="/vite/assets/use-disclosure-zKtK5W1r.js" as="script" crossorigin="anonymous">
<link rel="modulepreload" href="/vite/assets/use-hotkeys-Cnc_Rwkb.js" as="script" crossorigin="anonymous">
<link rel="modulepreload" href="/vite/assets/random-id-DOQyszCZ.js" as="script" crossorigin="anonymous">
<link rel="modulepreload" href="/vite/assets/notifications.store-C-3AFSMn.js" as="script" crossorigin="anonymous">
<link rel="modulepreload" href="/vite/assets/exports-C_MrNx_T.js" as="script" crossorigin="anonymous">
<link rel="modulepreload" href="/vite/assets/axios-BEvgo0ym.js" as="script" crossorigin="anonymous">
<link rel="modulepreload" href="/vite/assets/dayjs.min-BkKovM-s.js" as="script" crossorigin="anonymous">
<link rel="modulepreload" href="/vite/assets/i18next-BlSq9s7B.js" as="script" crossorigin="anonymous">
<link rel="modulepreload" href="/vite/assets/client-U9M77rxp.js" as="script" crossorigin="anonymous">
<link rel="modulepreload" href="/vite/assets/react-dom-DaLxUz_h.js" as="script" crossorigin="anonymous">
<link rel="modulepreload" href="/vite/assets/useTranslation-Bx1Cdrkz.js" as="script" crossorigin="anonymous">
<link rel="modulepreload" href="/vite/assets/compiler-runtime-6XxiPFnt.js" as="script" crossorigin="anonymous">
<link rel="modulepreload" href="/vite/assets/jsx-runtime-CwjcCKJi.js" as="script" crossorigin="anonymous">
<link rel="modulepreload" href="/vite/assets/react-CkL4ZRHB.js" as="script" crossorigin="anonymous">
<link rel="stylesheet" href="/vite/assets/application-BqhCP46M.js" />
<script src="/vite/assets/application-Df9RExpe.js" crossorigin="anonymous" type="module"></script><link rel="modulepreload" href="/vite/assets/chunk-DsPFFUou.js" as="script" crossorigin="anonymous">
<link rel="modulepreload" href="/vite/assets/autocomplete-VMNbxKGl.js" as="script" crossorigin="anonymous">
<link rel="modulepreload" href="/vite/assets/routes-CCH8ilKF.js" as="script" crossorigin="anonymous">
<link rel="modulepreload" href="/vite/assets/createPopper-C3aM9r1M.js" as="script" crossorigin="anonymous">
<link rel="modulepreload" href="/vite/assets/js.cookie-D1-O8zkX.js" as="script" crossorigin="anonymous"><link rel="stylesheet" href="/vite/assets/application-C8HjmMaq.css" media="screen" />
<script>
window.ym = function(){(ym.a=ym.a||[]).push(arguments)};
window.addEventListener('load', function() {
setTimeout(function() {
ym.l = 1*new Date();
ym(window.gon.ym_counter, "init", {
clickmap: true,
trackLinks: true,
accurateTrackBounce: true,
webvisor: true
});
// Загружаем скрипт
var k = document.createElement('script');
k.async = 1;
k.src = 'https://mc.yandex.ru/metrika/tag.js';
document.head.appendChild(k);
ym(window.gon.ym_counter, 'getClientID', function(clientID) {
window.ymClientId = clientID;
});
}, 1500);
});
</script>
<!-- Google Tag Manager - deferred -->
<script>
// dataLayer stub сразу — пуши работают до загрузки скрипта
window.dataLayer = window.dataLayer || [];
// Сам скрипт — отложенно после load
window.addEventListener('load', function() {
setTimeout(function() {
dataLayer.push({'gtm.start': new Date().getTime(), event: 'gtm.js'});
var j = document.createElement('script');
j.async = true;
j.src = 'https://www.googletagmanager.com/gtm.js?id=GTM-WK88TH';
document.head.appendChild(j);
}, 1500);
});
</script>
<!-- End Google Tag Manager -->
</head>
<body>
<noscript>
<div>
<img alt="" src="https://mc.yandex.ru/watch/25559621" style="position:absolute; left:-9999px;">
</div>
</noscript>
<header class="sticky-top bg-body">
<nav class="navbar navbar-expand-lg">
<div class="container-xxl">
<a class="navbar-brand" href="/"><img alt="Логотип Хекслета" height="24" src="https://ru.hexlet.io/vite/assets/logo_ru_light-BpiEA1LT.svg" width="96">
</a><button aria-controls="collapsable" aria-expanded="false" aria-label="Меню" class="navbar-toggler border-0 mb-0 mt-1" data-bs-target="#collapsable" data-bs-toggle="collapse">
<span class="navbar-toggler-icon"></span>
</button>
<div class="collapse navbar-collapse" id="collapsable">
<ul class="navbar-nav mb-lg-0 mt-lg-1">
<li class="nav-item dropdown">
<button aria-haspopup class="btn nav-link" data-bs-toggle="dropdown" type="button">
Все курсы
<span class="bi bi-chevron-down align-middle ms-1"></span>
</button>
<ul class="dropdown-menu">
<li>
<a class="dropdown-item d-flex py-2" href="/courses"><div class="fw-bold me-auto">Все что есть</div>
<div class="text-muted">117</div>
</a></li>
<li>
<hr class="dropdown-divider">
</li>
<li class="dropdown-item">
<b>Популярные категории</b>
</li>
<li>
<a class="dropdown-item py-2" href="/courses_devops">Курсы по DevOps
</a></li>
<li>
<a class="dropdown-item py-2" href="/courses_data_analytics">Курсы по аналитике данных
</a></li>
<li>
<a class="dropdown-item py-2" href="/courses_programming">Курсы по программированию
</a></li>
<li>
<a class="dropdown-item py-2" href="/courses_testing">Курсы по тестированию
</a></li>
<li>
<hr class="dropdown-divider">
</li>
<li class="dropdown-item">
<b>Популярные курсы</b>
</li>
<li>
<a class="dropdown-item py-2" href="/programs/devops-engineer-from-scratch">DevOps-инженер с нуля
</a></li>
<li>
<a class="dropdown-item py-2" href="/programs/go">Go-разработчик
</a></li>
<li>
<a class="dropdown-item py-2" href="/programs/java">Java-разработчик
</a></li>
<li>
<a class="dropdown-item py-2" href="/programs/python">Python-разработчик
</a></li>
<li>
<a class="dropdown-item py-2" href="/programs/qa-auto-engineer-java">Автоматизатор тестирования на Java
</a></li>
<li>
<a class="dropdown-item py-2" href="/programs/data-analytics">Аналитик данных
</a></li>
<li>
<a class="dropdown-item py-2" href="/programs/frontend">Фронтенд-разработчик
</a></li>
</ul>
</li>
<li class="nav-item dropdown">
<button aria-haspopup class="btn nav-link" data-bs-toggle="dropdown" type="button">
О Хекслете
<span class="bi bi-chevron-down align-middle"></span>
</button>
<ul class="dropdown-menu bg-body">
<li>
<a class="dropdown-item py-2" href="/pages/about">О нас
</a></li>
<li>
<a class="dropdown-item py-2" href="/blog">Блог
</a></li>
<li>
<span class="dropdown-item py-2 external-link" data-href="https://special.hexlet.io/hse-research" role="button">Результаты (Исследование)
</span></li>
<li>
<span class="dropdown-item py-2 external-link" data-href="https://career.hexlet.io" role="button">Хекслет Карьера
</span></li>
<li>
<a class="dropdown-item py-2" href="/testimonials">Отзывы студентов
</a></li>
<li>
<span class="dropdown-item py-2 external-link" data-href="https://t.me/hexlet_help_bot" role="button">Поддержка (В ТГ)
</span></li>
<li>
<span class="dropdown-item py-2 external-link" data-href="https://special.hexlet.io/referal-program/?promo_creative=priglasite-druzei&promo_name=referal-program&promo_position=promo_position&promo_start=010724&promo_type=link" role="button">Реферальная программа
</span></li>
<li>
<span class="dropdown-item py-2 external-link" data-href="https://special.hexlet.io/certificate" role="button">Подарочные сертификаты
</span></li>
<li>
<span class="dropdown-item py-2 external-link" data-href="https://hh.ru/employer/4307094" role="button">Вакансии
</span></li>
<li>
<span class="dropdown-item d-flex external-link" rel="noopener noreferrer nofollow" data-href="https://b2b.hexlet.io" data-target="_blank" role="button">Компаниям
</span></li>
<li>
<span class="dropdown-item d-flex external-link" rel="noopener noreferrer nofollow" data-href="https://hexly.ru/" data-target="_blank" role="button">Колледж
</span></li>
<li>
<span class="dropdown-item d-flex external-link" rel="noopener noreferrer nofollow" data-href="https://hexlyschool.ru/" data-target="_blank" role="button">Частная школа
</span></li>
</ul>
</li>
<li><a class="nav-link" href="/subscription/new">Подписка</a></li>
</ul>
<ul class="navbar-nav flex-lg-row align-items-lg-center gap-2 ms-auto">
<li>
<a class="nav-link" aria-label="Переключить тему" href="/theme/switch?new_theme=dark"><span aria-hidden="true" class="bi bi-moon"></span>
</a></li>
<li>
<span data-target="_self" class="nav-link external-link" data-href="/u/new" role="button"><span>Регистрация</span>
</span></li>
<li>
<span data-target="_self" class="nav-link external-link" data-href="https://ru.hexlet.io/session/new" role="button"><span>Вход</span>
</span></li>
</ul>
</div>
</div>
</nav>
</header>
<div class="x-container-xxxl">
</div>
<main class="mb-6 min-vh-100 h-100">
<link rel="preload" as="image" href="https://hexlet.io/rails/active_storage/representations/proxy/eyJfcmFpbHMiOnsiZGF0YSI6MzcyNywicHVyIjoiYmxvYl9pZCJ9fQ==--2d5cbbf5c3b4a73ae4b2c50632305d78f5872e4d/eyJfcmFpbHMiOnsiZGF0YSI6eyJmb3JtYXQiOiJ3ZWJwIiwicmVzaXplX3RvX2xpbWl0IjpbNDAwLDQwMF0sInNhdmVyIjp7InF1YWxpdHkiOjg1fX0sInB1ciI6InZhcmlhdGlvbiJ9fQ==--5b6f46dacd1af664f27558553a58076185091823/Programmer-rafiki.png"/><link rel="preload" as="image" href="https://hexlet.io/rails/active_storage/representations/proxy/eyJfcmFpbHMiOnsiZGF0YSI6NDAzNCwicHVyIjoiYmxvYl9pZCJ9fQ==--ba516ea9573bdfcd1d21e2aa0fff8818561828f2/eyJfcmFpbHMiOnsiZGF0YSI6eyJmb3JtYXQiOiJ3ZWJwIiwicmVzaXplX3RvX2xpbWl0IjpbNDAwLDQwMF0sInNhdmVyIjp7InF1YWxpdHkiOjg1fX0sInB1ciI6InZhcmlhdGlvbiJ9fQ==--5b6f46dacd1af664f27558553a58076185091823/Typing-bro.png"/><link rel="preload" as="image" href="https://hexlet.io/rails/active_storage/representations/proxy/eyJfcmFpbHMiOnsiZGF0YSI6NDAwNCwicHVyIjoiYmxvYl9pZCJ9fQ==--43a2eb3595eeebb3357d478cbcb752d0026363de/eyJfcmFpbHMiOnsiZGF0YSI6eyJmb3JtYXQiOiJ3ZWJwIiwicmVzaXplX3RvX2xpbWl0IjpbNDAwLDQwMF0sInNhdmVyIjp7InF1YWxpdHkiOjg1fX0sInB1ciI6InZhcmlhdGlvbiJ9fQ==--5b6f46dacd1af664f27558553a58076185091823/Website%20Creator-cuate.png"/><link rel="preload" as="image" href="https://hexlet.io/rails/active_storage/representations/proxy/eyJfcmFpbHMiOnsiZGF0YSI6MzY4NywicHVyIjoiYmxvYl9pZCJ9fQ==--8b6c104f41f902085a7d6e50ea73457f84a3ac33/eyJfcmFpbHMiOnsiZGF0YSI6eyJmb3JtYXQiOiJ3ZWJwIiwicmVzaXplX3RvX2xpbWl0IjpbNDAwLDQwMF0sInNhdmVyIjp7InF1YWxpdHkiOjg1fX0sInB1ciI6InZhcmlhdGlvbiJ9fQ==--5b6f46dacd1af664f27558553a58076185091823/Coding-amico.png"/><link rel="preload" as="image" href="https://hexlet.io/rails/active_storage/representations/proxy/eyJfcmFpbHMiOnsiZGF0YSI6MzY3OSwicHVyIjoiYmxvYl9pZCJ9fQ==--63b1e4a498081a9ffcf9ba460ef4249e57663579/eyJfcmFpbHMiOnsiZGF0YSI6eyJmb3JtYXQiOiJ3ZWJwIiwicmVzaXplX3RvX2xpbWl0IjpbNDAwLDQwMF0sInNhdmVyIjp7InF1YWxpdHkiOjg1fX0sInB1ciI6InZhcmlhdGlvbiJ9fQ==--5b6f46dacd1af664f27558553a58076185091823/Coding%20workshop-pana.png"/><link rel="preload" as="image" href="/vite/assets/development-BVihs_d5.png"/><div id="app" data-page="{"component":"web/qna/questions/show","props":{"errors":{},"locale":"ru","language":"ru","httpsHost":"https://ru.hexlet.io","host":"ru.hexlet.io","colorScheme":"light","auth":{"user":{"id":null,"last_viewed_notification_id":null,"email":null,"state":null,"first_name":"","last_name":"","created_at":"2026-02-26T23:07:06.738Z","current_program":null,"current_team":null,"full_name":"","guest":true,"can_use_paid_features":false,"is_hexlet_employee":false,"sanitized_phone_number":"","can_subscribe":true,"can_renew_education":false}},"cloudflareTurnstileSiteKey":"0x4AAAAAAA15KmeFXzd2H0Xo","vkIdClientId":"51586979","yandexIdClientId":"88d071f1d3384eb4bd1deb37910235c7","formAuthToken":"pVGzUmjXkPTbQQFG-TgDGwJc7JqHOuZxiOyNr6kosV1KgHhlmqk9lG0CJd71N_NswlXBMI8NGNM1DBf7-y9WMw","category":{"id":15,"title":"Глоссарий","slug":"glossary","questions_count":382,"locale":"ru"},"mainStackCategory":{"id":2,"name":"Курсы по веб-разработке","slug":"web_development","short_name":"Веб-разработка","order":190,"state":"published","category_slug":"courses_web_development"},"answerDto":{"id":null,"body":"","meta":{"model":"question_answer","relations":{}}},"question":{"creator":{"id":104929,"email":"feycot@gmail.com","first_name":"Nikolai","last_name":"Gagarinov","telegram":"","full_name":"Nikolai Gagarinov","removed":false},"category":{"id":15,"title":"Глоссарий","slug":"glossary","questions_count":382,"locale":"ru"},"tags":[],"id":3656,"answers_count":2,"slug":"chto-takoe-iframe","state":"published","title":"iFrame","created_at":"2023-06-05T10:02:21.197Z","details":null,"best_answer_id":5354,"related_stacks_count":5},"answers":[{"user":{"id":104929,"email":"feycot@gmail.com","first_name":"Nikolai","last_name":"Gagarinov","telegram":"","full_name":"Nikolai Gagarinov","removed":false},"question":{"creator":{"id":104929,"email":"feycot@gmail.com","first_name":"Nikolai","last_name":"Gagarinov","telegram":"","full_name":"Nikolai Gagarinov","removed":false},"category":{"id":15,"title":"Глоссарий","slug":"glossary","questions_count":382,"locale":"ru"},"tags":[],"id":3656,"answers_count":2,"slug":"chto-takoe-iframe","state":"published","title":"iFrame","created_at":"2023-06-05T10:02:21.197Z","details":null,"best_answer_id":5354,"related_stacks_count":5},"id":5354,"state":"active","body":"Элемент **iFrame** уже много лет остаётся одной из ключевых технологий для встраивания внешнего контента на веб-страницы. Он позволяет отображать внутри сайта независимую страницу или приложение, фактически создавая автономное окно, которое существует отдельно от основного DOM. Такая изоляция делает iFrame удобным инструментом для интеграции сервисов, не требующих глубокого взаимодействия с сайтом-хостом. Несмотря на активное развитие API-интеграций, web-компонентов и других современных техник, iFrame продолжает широко использоваться благодаря своей универсальности, простоте внедрения, кроссбраузерной стабильности.\n\n\n\n## Определение и назначение\n\n**iFrame (inline frame)** — это HTML-элемент, позволяющий встроить одну веб-страницу в другую, при этом обеспечивая четкое разграничение контентных областей. Он загружает внешний документ в собственный изолированный контекст браузера, что делает его своеобразной «песочницей» для размещения стороннего функционала.\n\nБазовый пример синтаксиса:\n\n```html\n<iframe src=\"https://example.com\" width=\"600\" height=\"400\"></iframe>\n```\n\nЭтот элемент остается незаменимым для разработчиков, которым нужно быстро внедрить внешний функционал без сложных интеграций. В отличие от `<embed>` или `<object>`, iFrame обладает более стабильной структурой отображения и гибкими настройками поведения.\n\nС его помощью можно решать задачи разной сложности — от простого встраивания видео до размещения целых внешних приложений. Именно поэтому iFrame до сих пор широко используется в маркетинге, аналитике, e-commerce, обучающих платформах и корпоративных системах.\n\n## Применение iFrame\n\nОбласть применения iFrame чрезвычайно широкая, особенно в ситуациях, когда требуется встроить сторонний контент, не адаптируя его под стилистику или архитектуру сайта. Такой подход позволяет сохранить неизменным внешний вид и поведение внешнего ресурса, что особенно важно при работе с сервисами, которые должны выглядеть и функционировать одинаково на всех площадках. Благодаря изоляции фрейма и отсутствию конфликтов с хост-страницей, iFrame остается удобным инструментом для размещения готовых решений.\n\n### Встраивание мультимедиа\n\niFrame стал стандартным способом размещения видеоплееров, презентаций, прямых трансляций и других медиаформатов. Платформы вроде YouTube, Vimeo, Rutube и образовательные сервисы используют именно этот подход, поскольку он обеспечивает стабильную работу плеера, защиту контента, независимость от стилей сайта. Такое решение позволяет сохранять полный контроль над воспроизведением, рекламными вставками, субтитрами и статистикой просмотров, не перегружая основной проект лишним функционалом.\n\n### Интерактивные карты\n\nСовременные картографические сервисы предоставляют готовые embed-виджеты, идеально работающие именно в iFrame. Благодаря этому сайты могут легко отображать схемы проезда, геолокацию, панорамы улиц, маршруты и геоданные без необходимости подключать сложные API. Такой подход особенно выгоден небольшим проектам, которым не нужна собственная логика работы карты: достаточно вставить код, настроить размер фрейма.\n\n### Внедрение сторонних сервисов\n\nЧерез iFrame можно встроить практически любой сервис, интерфейс которого должен сохраняться полностью:\n\n* формы бронирования;\n* CRM-виджеты для записи или обработки заявок;\n* платежные системы и кнопки;\n* окна онлайн-консультантов;\n* интерактивные калькуляторы, тесты.\n\nПоставщикам услуг удобно предоставлять именно формат iFrame, так как он гарантирует, что их продукт будет отображаться одинаково на всех сайтах, а внутренние стили, скрипты не вступят в конфликт с кодом площадки.\n\n### Вывод независимого или потенциально опасного контента\n\nВ ситуациях, когда требуется показать стороннюю страницу, содержащую нестабильный код, экспериментальную функциональность или административную панель, iFrame обеспечивает надежную изоляцию. Он создаёт отдельный контекст выполнения, не позволяя внешнему скрипту вмешиваться в работу основного сайта. Это делает фрейм удобным инструментом для тестирования, интеграции мониторинговых панелей или размещения контента, который может нарушить структуру основной страницы.\n\n## Безопасность iFrame\n\niFrame часто рассматривается как потенциально опасный инструмент, если используется неправильно. Он действительно может создавать уязвимости, но современные стандарты позволяют значительно снизить риски.\n\n### Основные угрозы\n\n#### *Кликджекинг*\n\nКликджекинг — одна из самых известных атак, связанных с iFrame. Ее суть заключается в том, что злоумышленник незаметно встраивает чужой сайт в прозрачный или маскированный iFrame и накладывает поверх него собственные элементы интерфейса. Пользователь думает, что нажимает на безопасную кнопку, но на самом деле совершает действие на реальном сайте — подтверждает покупку, изменяет настройки или передает данные. Именно из-за этого многие крупные сервисы намеренно запрещают отображение своих страниц во фреймах, минимизируя риск подобной подмены действий.\n\n#### *XSS через внешние фреймы*\n\nЕсли iFrame загружает непроверенный или потенциально опасный ресурс, внутри него может выполняться вредоносный JavaScript. В некоторых случаях такой скрипт способен попытаться взаимодействовать с родительской страницей, особенно если защита настроена неправильно. Это создает риск XSS-атак, фишинга, изменения DOM, перехвата данных пользователя. Проблема усиливается, когда фреймы используются без ограничений или разработчики доверяют внешним источникам без анализа безопасности.\n\n#### *Манипуляции с навигацией*\n\nНекорректно сконфигурированные iFrame могут изменять поведение браузера, перенаправлять пользователя на поддельные ресурсы или даже открывать всплывающие окна без его ведома. В прошлом такие атаки активно применялись мошенниками, чтобы уводить пользователей на фишинговые страницы или показывать рекламные баннеры. Именно поэтому защитные механизмы против таких действий были ужесточены на уровне браузеров, серверных настроек.\n\n## Механизмы защиты\n\n### sandbox\n\nАтрибут sandbox — один из самых эффективных способов защитить родительскую страницу от потенциально опасного содержимого во фрейме. Он создаёт строго ограниченную среду, где действия внешнего сайта контролируются, блокируются по умолчанию.\n\n```html\n<iframe src=\"...\" sandbox=\"allow-scripts allow-forms\"></iframe>\n```\n\nЕсли не указывать дополнительные разрешения:\n\n* **скрипты не смогут выполняться**,\n* **формы не будут отправляться**,\n* **клики по ссылкам не приведут к переходам**,\n* **доступ к большинству API браузера будет заблокирован**.\n\nТакой подход делает iFrame почти полностью безопасным, позволяет использовать его даже с незнакомым внешним контентом.\n\n### Content Security Policy (CSP)\n\nCSP даёт разработчику возможность контролировать, какие внешние ресурсы могут загружаться внутри сайта, его фреймов. С помощью директивы frame-src можно явно определить список доверенных доменов.\n\n```html\nframe-src https://trusted-domain.com;\n```\n\nЭто позволяет исключить загрузку непроверенных источников, предотвращает XSS-атаки и делает поведение iFrame предсказуемым. CSP — один из самых современных и гибких инструментов защиты.\n\n### X-Frame-Options\n\nНесмотря на то что этот механизм считается устаревшим, многие сайты по-прежнему используют его как дополнительный уровень защиты.\n\nЗаголовок:\n\n```html\nX-Frame-Options: SAMEORIGIN\n```\n\nзапрещает встраивание страницы в iFrame на других доменах. Это гарантирует, что злоумышленник не сможет открыть страницу на чужом сайте и использовать её для кликджекинга или скрытой подмены действий пользователя.\n\n## SEO и iFrame\n\nПоисковые системы относятся к содержимому, встроенному через iFrame, с большой осторожностью, это стоит учитывать при планировании SEO-стратегии. Для поисковиков iFrame чаще всего воспринимается как отдельный внешний элемент, не связанный напрямую с основным сайтом. Поэтому рассчитывать на то, что встроенный через него контент улучшит видимость ресурса в поиске, не приходится.\n\nПочему iFrame плохо влияет на продвижение:\n\n* **Контент внутри iFrame не считается частью вашего сайта.** Поисковые алгоритмы считают его принадлежащим исходному домену, а не странице, на которой он отображается.\n* **Он не индексируется как собственный текст.** Даже если внутри фрейма находится большая информационная статья, поисковики не учитывают её для ранжирования хоста — это всегда внешний ресурс.\n* **Поисковые роботы могут полностью игнорировать содержимое фрейма**, особенно если домен не разрешает индексирование или использует защитные заголовки.\n* **Ссылки внутри iFrame не передают ссылочный вес.** Это значит, что любые внешние ссылки, встроенные через фрейм, не учитываются в ссылочном профиле сайта и не помогают продвижению.\n\nПо этим причинам iFrame категорически не подходит для размещения важных текстов, SEO-статей, лендингов и другого контента, который должен участвовать в ранжировании. Использование фреймов для таких целей приведёт к потере позиций, снижению эффективности продвижения.\n\nТем не менее, для встраивания медиа, карт, платежных модулей, форм обратной связи, интерактивных сервисов iFrame остаётся полностью безопасным. Он не влияет на SEO в негативную сторону, поскольку такие элементы не предназначены для индексации и служат исключительно для улучшения функционала, удобства сайта.\n\n## Примеры использования iFrame\n\n### YouTube\n\n```html\n<iframe\n src=\"https://www.youtube.com/embed/VIDEO_ID\"\n allow=\"autoplay; encrypted-media\"\n allowfullscreen\n ></iframe>\n```\n\nВстраивание видео через YouTube стало стандартом благодаря удобству, универсальности iFrame. Такой способ позволяет разместить ролик на странице буквально за несколько секунд, без настройки дополнительных скриптов или модулей. Плеер автоматически подстраивается под размер контейнера, поддерживает разные форматы воспроизведения и остается полностью управляемым со стороны YouTube, что избавляет разработчиков от проблем с совместимостью, обновлениями.\n\n**Преимущества:**\n\n* быстрое внедрение даже для начинающих пользователей;\n* автоматическая адаптация под размер экрана, тип устройства;\n* официальный интерфейс с кнопками, настройками качества, подписями.\n\n### Google Maps\n\n```html\n<iframe\n src=\"https://www.google.com/maps/embed?pb=...\"\n loading=\"lazy\"\n></iframe>\n```\n\nВстраивание карт Google Maps через iFrame идеально подходит для сайтов, которым нужно показать посетителям локацию, маршруты или контактные данные компании. Такой вариант не требует настройки API и работает стабильно на всех устройствах. Он отлично подходит для страниц с адресами, профилей организаций, лендингов услуг, навигационных указателей.\n\n### Сторонние формы и сервисы\n\nЧерез iFrame можно встроить практически любые инструменты, требующие сохранения оригинального дизайна и поведения:\n\n* платежные виджеты;\n* квизы, интерактивные анкеты;\n* калькуляторы стоимости;\n* формы записи или заявок;\n* онлайн-чат или службу поддержки.\n\nТакой подход особенно удобен, когда сервисы предоставляют готовый embed-код. Это позволяет подключить функционал за минуты, без полноценной интеграции с API и сложной логики. Кроме того, iFrame изолирует внешний сервис от сайта, что повышает стабильность, предотвращает конфликты стилей, скриптов.\n\n## Альтернативы и современные подходы\n\n\n\nНесмотря на то что iFrame остаётся простым, универсальным и надежным инструментом, веб-разработка активно движется вперед, предлагая более гибкие и высокопроизводительные решения. Эти подходы позволяют избежать ограничений фреймов, ускорить загрузку страниц и повысить уровень безопасности при интеграции внешнего функционала.\n\n### API-интеграции\n\nAPI используют в тех случаях, когда требуется внедрить не готовый интерфейс, а только данные или логику. Такой метод позволяет максимально органично встроить функционал в структуру сайта, сохранив единый дизайн, поведение и UX.\n\nПреимущества API-интеграции:\n\n* динамический контент подгружается через JavaScript, что делает обновления незаметными, быстрыми;\n* сайт сохраняет собственную визуальную стилистику, контроль над разметкой;\n* это наиболее SEO-дружественный вариант, так как весь контент попадает в индекс поисковых систем;\n* архитектура остаётся гибкой, безопасной, легко масштабируемой.\n\nAPI — лучший выбор для сложных сервисов, систем с постоянными обновлениями, интерфейсов с высокой вариативностью и крупных проектов.\n\n### Web Components (Shadow DOM)\n\nТехнология Web Components позволяет создавать собственные элементы HTML, полностью изолированные от остальной разметки. Используя Shadow DOM, разработчики могут защищать стили и структуру компонента от влияния внешнего CSS и JavaScript.\n\nПреимущества:\n\n* полная защита от конфликтов CSS, глобальных стилей;\n* модульность интерфейса, что упрощает поддержку, повторное использование компонентов;\n* высокая скорость работы за счёт нативной поддержки браузерами;\n* возможность создавать масштабируемые systems design-библиотеки.\n\nФактически Web Components становятся «iFrame нового поколения», сохраняя изоляцию, но предлагая гораздо более плавную интеграцию, контроль.\n\n### Скриптовые виджеты\n\nМногие сервисы создают embed-коды на основе обычного:\n\n```html\n<script src=\"...\"></script>\n```\n\nПри подключении такого скрипта мини-приложение рендерится прямо внутри страницы, но без использования iFrame. Это экономит ресурсы и позволяет детальнее контролировать внешний вид, поведение виджета.\n\nПреимущества скриптовых виджетов:\n\n* высокая производительность;\n* отсутствие лишней изоляции;\n* гибкость интеграции;\n* легкость обновления функционала поставщиком.\n\n## Тренды и развитие\n\nСовременные технологии активно меняют подход к использованию iFrame. Хотя фреймы продолжают оставаться полезным инструментом, их роль постепенно сдвигается в сторону более специализированных и ограниченных сценариев.\n\n### iFrame в SPA\n\nВ одностраничных приложениях (SPA) iFrame применяется точечно, в основном как:\n\n* внешняя часть микросервиса,\n* безопасная среда для платёжных форм,\n* временная зона для подключения нестандартных интеграций.\n\nЗа счёт изоляции он помогает соблюдать требования безопасности и защищать ключевые части приложения.\n\n### Ограничение сторонних ресурсов\n\nРост внимания к приватности, безопасности данных повлиял на работу iFrame:\n\n* cookies внутри iFrame всё чаще становятся недоступными из-за строгих правил браузеров;\n* для некоторых сценариев требуется явное согласие пользователя;\n* многие сторонние ресурсы блокируются, если не соответствуют политикам безопасности.\n\nЭто усложняет внедрение старых решений, но делает веб-среду безопаснее, предсказуемее.\n\n### Рост микрофронтендов\n\nСовременные компании все чаще переходят на архитектуру микрофронтендов. Интерфейс собирается из независимых модулей, каждый из которых может быть создан и обновлён отдельной командой. В некоторых случаях такие модули изолируются внутри iFrame, чтобы:\n\n* избежать конфликтов стилей,\n* обеспечить устойчивую работу,\n* разделить ответственность между командами.\n\nТакой подход помогает масштабировать большие проекты, упрощает управление сложными интерфейсами.\n\n## Заключение\n\niFrame — это простая и надежная технология, которая остается актуальной несмотря на быстрый рост современных веб-решений. Он позволяет быстро внедрять внешний функционал, обеспечивать изоляцию, интегрировать сложные сервисы без переписывания кода. Однако использование iFrame требует понимания его ограничений — прежде всего в вопросах безопасности и SEO.\n\nСегодня iFrame часто применяется в связке с API, web-компонентами и SPA-архитектурой, дополняя новые подходы, обеспечивая удобную интеграцию сторонних интерфейсов.\n","votes_up_count":1,"votes_down_count":0,"created_at":"2025-12-18T18:02:38.406Z","user_id":104929,"category_slug":"glossary"},{"user":{"id":647057,"email":"redkinaelena10.02.89@yandex.ru","first_name":"Елена","last_name":"Редькина","telegram":"89670235676","full_name":"Елена Редькина","removed":false},"question":{"creator":{"id":104929,"email":"feycot@gmail.com","first_name":"Nikolai","last_name":"Gagarinov","telegram":"","full_name":"Nikolai Gagarinov","removed":false},"category":{"id":15,"title":"Глоссарий","slug":"glossary","questions_count":382,"locale":"ru"},"tags":[],"id":3656,"answers_count":2,"slug":"chto-takoe-iframe","state":"published","title":"iFrame","created_at":"2023-06-05T10:02:21.197Z","details":null,"best_answer_id":5354,"related_stacks_count":5},"id":3237,"state":"active","body":"iFrame - это элемент HTML, который позволяет встраивать содержимое одного документа в другой. Он создается с помощью тега <iframe> и содержит содержимое, указанное в атрибуте src. iFrame может использоваться для отображения содержимого других веб-страниц или документов внутри текущего документа, что позволяет создавать сложные веб-страницы с интегрированным содержимым из разных источников.","votes_up_count":0,"votes_down_count":0,"created_at":"2023-11-16T18:59:50.101Z","user_id":647057,"category_slug":"glossary"}],"relatedQuestions":[{"creator":{"id":583099,"email":"shade.mailbox@gmail.com","first_name":"Arthur","last_name":"Cheremisin","telegram":"","full_name":"Arthur Cheremisin","removed":false},"category":{"id":15,"title":"Глоссарий","slug":"glossary","questions_count":382,"locale":"ru"},"tags":[{"id":1095,"slug":"data-analitika","name":"data-аналитика"},{"id":1096,"slug":"analitika","name":"Аналитика"}],"id":2709,"answers_count":2,"slug":"chto-takoe-pandas","state":"published","title":"Pandas","created_at":"2023-03-29T12:39:32.428Z","details":"","best_answer_id":5306,"related_stacks_count":5},{"creator":{"id":104929,"email":"feycot@gmail.com","first_name":"Nikolai","last_name":"Gagarinov","telegram":"","full_name":"Nikolai Gagarinov","removed":false},"category":{"id":15,"title":"Глоссарий","slug":"glossary","questions_count":382,"locale":"ru"},"tags":[],"id":3577,"answers_count":1,"slug":"chto-takoe-1c-buhgalteriya","state":"published","title":"1C:Бухгалтерия","created_at":"2023-06-05T10:02:18.923Z","details":null,"best_answer_id":3315,"related_stacks_count":0},{"creator":{"id":104929,"email":"feycot@gmail.com","first_name":"Nikolai","last_name":"Gagarinov","telegram":"","full_name":"Nikolai Gagarinov","removed":false},"category":{"id":15,"title":"Глоссарий","slug":"glossary","questions_count":382,"locale":"ru"},"tags":[],"id":3578,"answers_count":1,"slug":"chto-takoe-1c-predpriyatie","state":"published","title":"1C:Предприятие","created_at":"2023-06-05T10:02:18.960Z","details":null,"best_answer_id":3314,"related_stacks_count":5},{"creator":{"id":104929,"email":"feycot@gmail.com","first_name":"Nikolai","last_name":"Gagarinov","telegram":"","full_name":"Nikolai Gagarinov","removed":false},"category":{"id":15,"title":"Глоссарий","slug":"glossary","questions_count":382,"locale":"ru"},"tags":[],"id":3579,"answers_count":1,"slug":"chto-takoe-a-b-testirovanie","state":"published","title":"A/B-тестирование","created_at":"2023-06-05T10:02:18.988Z","details":null,"best_answer_id":3313,"related_stacks_count":5},{"creator":{"id":104929,"email":"feycot@gmail.com","first_name":"Nikolai","last_name":"Gagarinov","telegram":"","full_name":"Nikolai Gagarinov","removed":false},"category":{"id":15,"title":"Глоссарий","slug":"glossary","questions_count":382,"locale":"ru"},"tags":[],"id":3580,"answers_count":1,"slug":"chto-takoe-agile","state":"published","title":"Agile","created_at":"2023-06-05T10:02:19.016Z","details":null,"best_answer_id":3312,"related_stacks_count":5}],"relatedLandings":[{"stack":{"id":12,"slug":"frontend","title":"Фронтенд-разработчик","audience":"for_beginners","start_type":"weekly","pricing_model":"purchase","priority":"high","kind":"profession","state":"published","stack_state":"finished","order":20,"duration_in_months":10},"id":17,"slug":"frontend","title":"Фронтенд-разработчик","subtitle":"Изучите HTML, CSS, JavaScript и React","subtitle_for_lists":"Изучите HTML, CSS, JavaScript и React","locale":"ru","current":true,"duration_in_months_text":"10 месяцев","stack_slug":"frontend","price_text":"от 6 792 ₽","duration_text":"10 месяцев","cover_list_variant":"https://hexlet.io/rails/active_storage/representations/proxy/eyJfcmFpbHMiOnsiZGF0YSI6MzcyNywicHVyIjoiYmxvYl9pZCJ9fQ==--2d5cbbf5c3b4a73ae4b2c50632305d78f5872e4d/eyJfcmFpbHMiOnsiZGF0YSI6eyJmb3JtYXQiOiJ3ZWJwIiwicmVzaXplX3RvX2xpbWl0IjpbNDAwLDQwMF0sInNhdmVyIjp7InF1YWxpdHkiOjg1fX0sInB1ciI6InZhcmlhdGlvbiJ9fQ==--5b6f46dacd1af664f27558553a58076185091823/Programmer-rafiki.png"},{"stack":{"id":19,"slug":"layout-designer","title":"Профессиональная верстка","audience":"for_beginners","start_type":"anytime","pricing_model":"purchase","priority":"medium","kind":"track","state":"published","stack_state":"finished","order":1700,"duration_in_months":5},"id":26,"slug":"professional-layout","title":"Профессиональная верстка","subtitle":"Навык адаптивной вёрстки с современными подходами для корректного отображения сайтов на любых устройствах и разрешениях","subtitle_for_lists":"Адаптивная вёрстка для отображения на любых устройствах ","locale":"ru","current":true,"duration_in_months_text":"5 месяцев","stack_slug":"layout-designer","price_text":"от 3 900 ₽","duration_text":"5 месяцев","cover_list_variant":"https://hexlet.io/rails/active_storage/representations/proxy/eyJfcmFpbHMiOnsiZGF0YSI6NDAzNCwicHVyIjoiYmxvYl9pZCJ9fQ==--ba516ea9573bdfcd1d21e2aa0fff8818561828f2/eyJfcmFpbHMiOnsiZGF0YSI6eyJmb3JtYXQiOiJ3ZWJwIiwicmVzaXplX3RvX2xpbWl0IjpbNDAwLDQwMF0sInNhdmVyIjp7InF1YWxpdHkiOjg1fX0sInB1ciI6InZhcmlhdGlvbiJ9fQ==--5b6f46dacd1af664f27558553a58076185091823/Typing-bro.png"},{"stack":{"id":41,"slug":"layout-designer-positioning","title":"Позиционирование в CSS","audience":"for_programmers","start_type":"anytime","pricing_model":"subscription","priority":"medium","kind":"track","state":"published","stack_state":"finished","order":4800,"duration_in_months":1},"id":70,"slug":"layout-designer-positioning","title":"Позиционирование в CSS","subtitle":"Навык разработки адаптивных интерфейсов, позволяющий создавать удобные и функциональные решения для различных устройств","subtitle_for_lists":"Получите навык работы с CSS и адаптивными интерфейсами","locale":"ru","current":true,"duration_in_months_text":"1 месяц","stack_slug":"layout-designer-positioning","price_text":"от 3 900 ₽","duration_text":"1 месяц","cover_list_variant":"https://hexlet.io/rails/active_storage/representations/proxy/eyJfcmFpbHMiOnsiZGF0YSI6NDAwNCwicHVyIjoiYmxvYl9pZCJ9fQ==--43a2eb3595eeebb3357d478cbcb752d0026363de/eyJfcmFpbHMiOnsiZGF0YSI6eyJmb3JtYXQiOiJ3ZWJwIiwicmVzaXplX3RvX2xpbWl0IjpbNDAwLDQwMF0sInNhdmVyIjp7InF1YWxpdHkiOjg1fX0sInB1ciI6InZhcmlhdGlvbiJ9fQ==--5b6f46dacd1af664f27558553a58076185091823/Website%20Creator-cuate.png"},{"stack":{"id":118,"slug":"web-development-free","title":"Основы веб-разработки","audience":"for_beginners","start_type":"anytime","pricing_model":"free","priority":"low","kind":"track","state":"published","stack_state":"finished","order":1000,"duration_in_months":1},"id":194,"slug":"web-development-free","title":"Основы веб-разработки","subtitle":"Изучите основы HTML, CSS и базовый JavaScript","subtitle_for_lists":null,"locale":"ru","current":true,"duration_in_months_text":"1 месяц","stack_slug":"web-development-free","price_text":"Бесплатно","duration_text":"1 месяц","cover_list_variant":"https://hexlet.io/rails/active_storage/representations/proxy/eyJfcmFpbHMiOnsiZGF0YSI6MzY4NywicHVyIjoiYmxvYl9pZCJ9fQ==--8b6c104f41f902085a7d6e50ea73457f84a3ac33/eyJfcmFpbHMiOnsiZGF0YSI6eyJmb3JtYXQiOiJ3ZWJwIiwicmVzaXplX3RvX2xpbWl0IjpbNDAwLDQwMF0sInNhdmVyIjp7InF1YWxpdHkiOjg1fX0sInB1ciI6InZhcmlhdGlvbiJ9fQ==--5b6f46dacd1af664f27558553a58076185091823/Coding-amico.png"},{"stack":{"id":299,"slug":"js-basics-free","title":"Основы JavaScript","audience":"for_beginners","start_type":"anytime","pricing_model":"free","priority":"low","kind":"track","state":"published","stack_state":"finished","order":1000,"duration_in_months":1},"id":221,"slug":"javascript-basics-free","title":"Основы JavaScript","subtitle":"Изучите язык JavaScript и его практическое применение","subtitle_for_lists":null,"locale":"ru","current":true,"duration_in_months_text":"1 месяц","stack_slug":"js-basics-free","price_text":"Бесплатно","duration_text":"1 месяц","cover_list_variant":"https://hexlet.io/rails/active_storage/representations/proxy/eyJfcmFpbHMiOnsiZGF0YSI6MzY3OSwicHVyIjoiYmxvYl9pZCJ9fQ==--63b1e4a498081a9ffcf9ba460ef4249e57663579/eyJfcmFpbHMiOnsiZGF0YSI6eyJmb3JtYXQiOiJ3ZWJwIiwicmVzaXplX3RvX2xpbWl0IjpbNDAwLDQwMF0sInNhdmVyIjp7InF1YWxpdHkiOjg1fX0sInB1ciI6InZhcmlhdGlvbiJ9fQ==--5b6f46dacd1af664f27558553a58076185091823/Coding%20workshop-pana.png"}]},"url":"/qna/glossary/questions/chto-takoe-iframe","version":"8f286f6358a90a7bef2263b3a6edf5a90a94fa42","encryptHistory":false,"clearHistory":false}"><style data-mantine-styles="true">:root, :host{--mantine-font-family: Arial, sans-serif;--mantine-font-family-headings: Arial, sans-serif;--mantine-heading-font-weight: normal;--mantine-radius-default: 0rem;--mantine-primary-color-filled: var(--mantine-color-indigo-filled);--mantine-primary-color-filled-hover: var(--mantine-color-indigo-filled-hover);--mantine-primary-color-light: var(--mantine-color-indigo-light);--mantine-primary-color-light-hover: var(--mantine-color-indigo-light-hover);--mantine-primary-color-light-color: var(--mantine-color-indigo-light-color);--mantine-spacing-xxl: calc(4rem * var(--mantine-scale));--mantine-font-size-xs: 12px;--mantine-font-size-sm: 14px;--mantine-font-size-md: 16px;--mantine-font-size-lg: clamp(16.0000px, calc(15.2727px + 0.2273vw), 18.0000px);--mantine-font-size-xl: clamp(16.0000px, calc(14.5455px + 0.4545vw), 20.0000px);--mantine-font-size-display-3: clamp(32.0000px, calc(26.1818px + 1.8182vw), 48.0000px);--mantine-font-size-display-2: clamp(36.0000px, calc(25.8182px + 3.1818vw), 64.0000px);--mantine-font-size-display-1: clamp(40.0000px, calc(25.4545px + 4.5455vw), 80.0000px);--mantine-font-size-h1: clamp(28.0000px, calc(23.6364px + 1.3636vw), 40.0000px);--mantine-font-size-h2: clamp(24.0000px, calc(21.0909px + 0.9091vw), 32.0000px);--mantine-font-size-h3: clamp(20.0000px, calc(17.0909px + 0.9091vw), 28.0000px);--mantine-font-size-h4: clamp(16.0000px, calc(13.0909px + 0.9091vw), 24.0000px);--mantine-font-size-h5: clamp(16.0000px, calc(14.5455px + 0.4545vw), 20.0000px);--mantine-font-size-h6: 1rem;--mantine-primary-color-0: var(--mantine-color-indigo-0);--mantine-primary-color-1: var(--mantine-color-indigo-1);--mantine-primary-color-2: var(--mantine-color-indigo-2);--mantine-primary-color-3: var(--mantine-color-indigo-3);--mantine-primary-color-4: var(--mantine-color-indigo-4);--mantine-primary-color-5: var(--mantine-color-indigo-5);--mantine-primary-color-6: var(--mantine-color-indigo-6);--mantine-primary-color-7: var(--mantine-color-indigo-7);--mantine-primary-color-8: var(--mantine-color-indigo-8);--mantine-primary-color-9: var(--mantine-color-indigo-9);--mantine-color-red-0: #ffeaea;--mantine-color-red-1: #fed4d4;--mantine-color-red-2: #f4a7a8;--mantine-color-red-3: #ec7878;--mantine-color-red-4: #e55050;--mantine-color-red-5: #e03131;--mantine-color-red-6: #e02829;--mantine-color-red-7: #c71a1c;--mantine-color-red-8: #b21218;--mantine-color-red-9: #9c0411;--mantine-color-violet-0: #fce9ff;--mantine-color-violet-1: #f1cfff;--mantine-color-violet-2: #e09bff;--mantine-color-violet-3: #d16fff;--mantine-color-violet-4: #be37fe;--mantine-color-violet-5: #b51afe;--mantine-color-violet-6: #b009ff;--mantine-color-violet-7: #9b00e4;--mantine-color-violet-8: #8a00cc;--mantine-color-violet-9: #7800b3;--mantine-color-indigo-0: #edecff;--mantine-color-indigo-1: #d6d5fe;--mantine-color-indigo-2: #aaa9f4;--mantine-color-indigo-3: #7b79eb;--mantine-color-indigo-4: #5451e4;--mantine-color-indigo-5: #3b37e0;--mantine-color-indigo-6: #2d2adf;--mantine-color-indigo-7: #1f1ec7;--mantine-color-indigo-8: #1819b2;--mantine-color-indigo-9: #0c149e;--mantine-color-cyan-0: #dffdff;--mantine-color-cyan-1: #caf5ff;--mantine-color-cyan-2: #99e8ff;--mantine-color-cyan-3: #64daff;--mantine-color-cyan-4: #3ccffe;--mantine-color-cyan-5: #24c8fe;--mantine-color-cyan-6: #00c2ff;--mantine-color-cyan-7: #00ade4;--mantine-color-cyan-8: #009acd;--mantine-color-cyan-9: #0085b5;--mantine-color-green-0: #e9fdec;--mantine-color-green-1: #d7f6dc;--mantine-color-green-2: #b0eab9;--mantine-color-green-3: #86df94;--mantine-color-green-4: #62d574;--mantine-color-green-5: #4ccf5f;--mantine-color-green-6: #3fcc54;--mantine-color-green-7: #2fb344;--mantine-color-green-8: #25a03b;--mantine-color-green-9: #138a2e;--mantine-color-yellow-0: #fff7e2;--mantine-color-yellow-1: #ffeecd;--mantine-color-yellow-2: #ffdc9c;--mantine-color-yellow-3: #ffc966;--mantine-color-yellow-4: #feb93a;--mantine-color-yellow-5: #feae1e;--mantine-color-yellow-6: #ffa90f;--mantine-color-yellow-8: #ca8200;--mantine-color-yellow-9: #af7000;--mantine-h1-font-size: clamp(28.0000px, calc(23.6364px + 1.3636vw), 40.0000px);--mantine-h1-font-weight: normal;--mantine-h2-font-size: clamp(24.0000px, calc(21.0909px + 0.9091vw), 32.0000px);--mantine-h2-font-weight: normal;--mantine-h3-font-size: clamp(20.0000px, calc(17.0909px + 0.9091vw), 28.0000px);--mantine-h3-font-weight: normal;--mantine-h4-font-size: clamp(16.0000px, calc(13.0909px + 0.9091vw), 24.0000px);--mantine-h4-font-weight: normal;--mantine-h5-font-size: clamp(16.0000px, calc(14.5455px + 0.4545vw), 20.0000px);--mantine-h5-font-weight: normal;--mantine-h6-font-size: 1rem;--mantine-h6-font-weight: normal;}
:root[data-mantine-color-scheme="dark"], :host([data-mantine-color-scheme="dark"]){--mantine-color-anchor: var(--mantine-color-text);--mantine-color-dimmed: #495057;--mantine-color-dark-filled: var(--mantine-color-dark-5);--mantine-color-dark-filled-hover: var(--mantine-color-dark-6);--mantine-color-dark-light: rgba(105, 105, 105, 0.15);--mantine-color-dark-light-hover: rgba(105, 105, 105, 0.2);--mantine-color-dark-light-color: var(--mantine-color-dark-0);--mantine-color-dark-outline: var(--mantine-color-dark-1);--mantine-color-dark-outline-hover: rgba(184, 184, 184, 0.05);--mantine-color-gray-filled: var(--mantine-color-gray-5);--mantine-color-gray-filled-hover: var(--mantine-color-gray-6);--mantine-color-gray-light: rgba(222, 226, 230, 0.15);--mantine-color-gray-light-hover: rgba(222, 226, 230, 0.2);--mantine-color-gray-light-color: var(--mantine-color-gray-0);--mantine-color-gray-outline: var(--mantine-color-gray-1);--mantine-color-gray-outline-hover: rgba(241, 243, 245, 0.05);--mantine-color-red-filled: var(--mantine-color-red-5);--mantine-color-red-filled-hover: var(--mantine-color-red-6);--mantine-color-red-light: rgba(236, 120, 120, 0.15);--mantine-color-red-light-hover: rgba(236, 120, 120, 0.2);--mantine-color-red-light-color: var(--mantine-color-red-0);--mantine-color-red-outline: var(--mantine-color-red-1);--mantine-color-red-outline-hover: rgba(254, 212, 212, 0.05);--mantine-color-pink-filled: var(--mantine-color-pink-5);--mantine-color-pink-filled-hover: var(--mantine-color-pink-6);--mantine-color-pink-light: rgba(250, 162, 193, 0.15);--mantine-color-pink-light-hover: rgba(250, 162, 193, 0.2);--mantine-color-pink-light-color: var(--mantine-color-pink-0);--mantine-color-pink-outline: var(--mantine-color-pink-1);--mantine-color-pink-outline-hover: rgba(255, 222, 235, 0.05);--mantine-color-grape-filled: var(--mantine-color-grape-5);--mantine-color-grape-filled-hover: var(--mantine-color-grape-6);--mantine-color-grape-light: rgba(229, 153, 247, 0.15);--mantine-color-grape-light-hover: rgba(229, 153, 247, 0.2);--mantine-color-grape-light-color: var(--mantine-color-grape-0);--mantine-color-grape-outline: var(--mantine-color-grape-1);--mantine-color-grape-outline-hover: rgba(243, 217, 250, 0.05);--mantine-color-violet-filled: var(--mantine-color-violet-5);--mantine-color-violet-filled-hover: var(--mantine-color-violet-6);--mantine-color-violet-light: rgba(209, 111, 255, 0.15);--mantine-color-violet-light-hover: rgba(209, 111, 255, 0.2);--mantine-color-violet-light-color: var(--mantine-color-violet-0);--mantine-color-violet-outline: var(--mantine-color-violet-1);--mantine-color-violet-outline-hover: rgba(241, 207, 255, 0.05);--mantine-color-indigo-filled: var(--mantine-color-indigo-5);--mantine-color-indigo-filled-hover: var(--mantine-color-indigo-6);--mantine-color-indigo-light: rgba(123, 121, 235, 0.15);--mantine-color-indigo-light-hover: rgba(123, 121, 235, 0.2);--mantine-color-indigo-light-color: var(--mantine-color-indigo-0);--mantine-color-indigo-outline: var(--mantine-color-indigo-1);--mantine-color-indigo-outline-hover: rgba(214, 213, 254, 0.05);--mantine-color-blue-filled: var(--mantine-color-blue-5);--mantine-color-blue-filled-hover: var(--mantine-color-blue-6);--mantine-color-blue-light: rgba(116, 192, 252, 0.15);--mantine-color-blue-light-hover: rgba(116, 192, 252, 0.2);--mantine-color-blue-light-color: var(--mantine-color-blue-0);--mantine-color-blue-outline: var(--mantine-color-blue-1);--mantine-color-blue-outline-hover: rgba(208, 235, 255, 0.05);--mantine-color-cyan-filled: var(--mantine-color-cyan-5);--mantine-color-cyan-filled-hover: var(--mantine-color-cyan-6);--mantine-color-cyan-light: rgba(100, 218, 255, 0.15);--mantine-color-cyan-light-hover: rgba(100, 218, 255, 0.2);--mantine-color-cyan-light-color: var(--mantine-color-cyan-0);--mantine-color-cyan-outline: var(--mantine-color-cyan-1);--mantine-color-cyan-outline-hover: rgba(202, 245, 255, 0.05);--mantine-color-teal-filled: var(--mantine-color-teal-5);--mantine-color-teal-filled-hover: var(--mantine-color-teal-6);--mantine-color-teal-light: rgba(99, 230, 190, 0.15);--mantine-color-teal-light-hover: rgba(99, 230, 190, 0.2);--mantine-color-teal-light-color: var(--mantine-color-teal-0);--mantine-color-teal-outline: var(--mantine-color-teal-1);--mantine-color-teal-outline-hover: rgba(195, 250, 232, 0.05);--mantine-color-green-filled: var(--mantine-color-green-5);--mantine-color-green-filled-hover: var(--mantine-color-green-6);--mantine-color-green-light: rgba(134, 223, 148, 0.15);--mantine-color-green-light-hover: rgba(134, 223, 148, 0.2);--mantine-color-green-light-color: var(--mantine-color-green-0);--mantine-color-green-outline: var(--mantine-color-green-1);--mantine-color-green-outline-hover: rgba(215, 246, 220, 0.05);--mantine-color-lime-filled: var(--mantine-color-lime-5);--mantine-color-lime-filled-hover: var(--mantine-color-lime-6);--mantine-color-lime-light: rgba(192, 235, 117, 0.15);--mantine-color-lime-light-hover: rgba(192, 235, 117, 0.2);--mantine-color-lime-light-color: var(--mantine-color-lime-0);--mantine-color-lime-outline: var(--mantine-color-lime-1);--mantine-color-lime-outline-hover: rgba(233, 250, 200, 0.05);--mantine-color-yellow-filled: var(--mantine-color-yellow-5);--mantine-color-yellow-filled-hover: var(--mantine-color-yellow-6);--mantine-color-yellow-light: rgba(255, 201, 102, 0.15);--mantine-color-yellow-light-hover: rgba(255, 201, 102, 0.2);--mantine-color-yellow-light-color: var(--mantine-color-yellow-0);--mantine-color-yellow-outline: var(--mantine-color-yellow-1);--mantine-color-yellow-outline-hover: rgba(255, 238, 205, 0.05);--mantine-color-orange-filled: var(--mantine-color-orange-5);--mantine-color-orange-filled-hover: var(--mantine-color-orange-6);--mantine-color-orange-light: rgba(255, 192, 120, 0.15);--mantine-color-orange-light-hover: rgba(255, 192, 120, 0.2);--mantine-color-orange-light-color: var(--mantine-color-orange-0);--mantine-color-orange-outline: var(--mantine-color-orange-1);--mantine-color-orange-outline-hover: rgba(255, 232, 204, 0.05);--app-cta-gradient: linear-gradient(90deg, var(--mantine-color-blue-9) 0%, var(--mantine-color-cyan-7) 100%);--app-color-surface: #2e2e2e;}
:root[data-mantine-color-scheme="light"], :host([data-mantine-color-scheme="light"]){--mantine-color-anchor: var(--mantine-color-text);--mantine-color-dimmed: #495057;--mantine-color-red-light: rgba(224, 40, 41, 0.1);--mantine-color-red-light-hover: rgba(224, 40, 41, 0.12);--mantine-color-red-outline-hover: rgba(224, 40, 41, 0.05);--mantine-color-violet-light: rgba(176, 9, 255, 0.1);--mantine-color-violet-light-hover: rgba(176, 9, 255, 0.12);--mantine-color-violet-outline-hover: rgba(176, 9, 255, 0.05);--mantine-color-indigo-light: rgba(45, 42, 223, 0.1);--mantine-color-indigo-light-hover: rgba(45, 42, 223, 0.12);--mantine-color-indigo-outline-hover: rgba(45, 42, 223, 0.05);--mantine-color-cyan-light: rgba(0, 194, 255, 0.1);--mantine-color-cyan-light-hover: rgba(0, 194, 255, 0.12);--mantine-color-cyan-outline-hover: rgba(0, 194, 255, 0.05);--mantine-color-green-light: rgba(63, 204, 84, 0.1);--mantine-color-green-light-hover: rgba(63, 204, 84, 0.12);--mantine-color-green-outline-hover: rgba(63, 204, 84, 0.05);--mantine-color-yellow-light: rgba(255, 169, 15, 0.1);--mantine-color-yellow-light-hover: rgba(255, 169, 15, 0.12);--mantine-color-yellow-outline-hover: rgba(255, 169, 15, 0.05);--app-color-surface: #f1f3f5;--app-cta-gradient: linear-gradient(90deg, var(--mantine-color-blue-filled) 0%, var(--mantine-color-cyan-5) 100%);}</style><style data-mantine-styles="classes">@media (max-width: 35.99375em) {.mantine-visible-from-xs {display: none !important;}}@media (min-width: 36em) {.mantine-hidden-from-xs {display: none !important;}}@media (max-width: 47.99375em) {.mantine-visible-from-sm {display: none !important;}}@media (min-width: 48em) {.mantine-hidden-from-sm {display: none !important;}}@media (max-width: 61.99375em) {.mantine-visible-from-md {display: none !important;}}@media (min-width: 62em) {.mantine-hidden-from-md {display: none !important;}}@media (max-width: 74.99375em) {.mantine-visible-from-lg {display: none !important;}}@media (min-width: 75em) {.mantine-hidden-from-lg {display: none !important;}}@media (max-width: 87.99375em) {.mantine-visible-from-xl {display: none !important;}}@media (min-width: 88em) {.mantine-hidden-from-xl {display: none !important;}}</style><script type="application/ld+json">{"@context":"https://schema.org","@type":"QAPage","mainEntity":{"@type":"Question","name":"iFrame","answerCount":2,"datePublished":"2023-06-05T10:02:21.197Z","author":{"@type":"Person","name":"Nikolai Gagarinov"},"acceptedAnswer":{"@type":"Answer","text":"Элемент **iFrame** уже много лет остаётся одной из ключевых технологий для встраивания внешнего контента на веб-страницы. Он позволяет отображать внутри сайта независимую страницу или приложение, фактически создавая автономное окно, которое существует отдельно от основного DOM. Такая изоляция делает iFrame удобным инструментом для интеграции сервисов, не требующих глубокого взаимодействия с сайтом-хостом. Несмотря на активное развитие API-интеграций, web-компонентов и других современных техник, iFrame продолжает широко использоваться благодаря своей универсальности, простоте внедрения, кроссбраузерной стабильности.\n\n\n\n## Определение и назначение\n\n**iFrame (inline frame)** — это HTML-элемент, позволяющий встроить одну веб-страницу в другую, при этом обеспечивая четкое разграничение контентных областей. Он загружает внешний документ в собственный изолированный контекст браузера, что делает его своеобразной «песочницей» для размещения стороннего функционала.\n\nБазовый пример синтаксиса:\n\n```html\n<iframe src="https://example.com" width="600" height="400"></iframe>\n```\n\nЭтот элемент остается незаменимым для разработчиков, которым нужно быстро внедрить внешний функционал без сложных интеграций. В отличие от `<embed>` или `<object>`, iFrame обладает более стабильной структурой отображения и гибкими настройками поведения.\n\nС его помощью можно решать задачи разной сложности — от простого встраивания видео до размещения целых внешних приложений. Именно поэтому iFrame до сих пор широко используется в маркетинге, аналитике, e-commerce, обучающих платформах и корпоративных системах.\n\n## Применение iFrame\n\nОбласть применения iFrame чрезвычайно широкая, особенно в ситуациях, когда требуется встроить сторонний контент, не адаптируя его под стилистику или архитектуру сайта. Такой подход позволяет сохранить неизменным внешний вид и поведение внешнего ресурса, что особенно важно при работе с сервисами, которые должны выглядеть и функционировать одинаково на всех площадках. Благодаря изоляции фрейма и отсутствию конфликтов с хост-страницей, iFrame остается удобным инструментом для размещения готовых решений.\n\n### Встраивание мультимедиа\n\niFrame стал стандартным способом размещения видеоплееров, презентаций, прямых трансляций и других медиаформатов. Платформы вроде YouTube, Vimeo, Rutube и образовательные сервисы используют именно этот подход, поскольку он обеспечивает стабильную работу плеера, защиту контента, независимость от стилей сайта. Такое решение позволяет сохранять полный контроль над воспроизведением, рекламными вставками, субтитрами и статистикой просмотров, не перегружая основной проект лишним функционалом.\n\n### Интерактивные карты\n\nСовременные картографические сервисы предоставляют готовые embed-виджеты, идеально работающие именно в iFrame. Благодаря этому сайты могут легко отображать схемы проезда, геолокацию, панорамы улиц, маршруты и геоданные без необходимости подключать сложные API. Такой подход особенно выгоден небольшим проектам, которым не нужна собственная логика работы карты: достаточно вставить код, настроить размер фрейма.\n\n### Внедрение сторонних сервисов\n\nЧерез iFrame можно встроить практически любой сервис, интерфейс которого должен сохраняться полностью:\n\n* формы бронирования;\n* CRM-виджеты для записи или обработки заявок;\n* платежные системы и кнопки;\n* окна онлайн-консультантов;\n* интерактивные калькуляторы, тесты.\n\nПоставщикам услуг удобно предоставлять именно формат iFrame, так как он гарантирует, что их продукт будет отображаться одинаково на всех сайтах, а внутренние стили, скрипты не вступят в конфликт с кодом площадки.\n\n### Вывод независимого или потенциально опасного контента\n\nВ ситуациях, когда требуется показать стороннюю страницу, содержащую нестабильный код, экспериментальную функциональность или административную панель, iFrame обеспечивает надежную изоляцию. Он создаёт отдельный контекст выполнения, не позволяя внешнему скрипту вмешиваться в работу основного сайта. Это делает фрейм удобным инструментом для тестирования, интеграции мониторинговых панелей или размещения контента, который может нарушить структуру основной страницы.\n\n## Безопасность iFrame\n\niFrame часто рассматривается как потенциально опасный инструмент, если используется неправильно. Он действительно может создавать уязвимости, но современные стандарты позволяют значительно снизить риски.\n\n### Основные угрозы\n\n#### *Кликджекинг*\n\nКликджекинг — одна из самых известных атак, связанных с iFrame. Ее суть заключается в том, что злоумышленник незаметно встраивает чужой сайт в прозрачный или маскированный iFrame и накладывает поверх него собственные элементы интерфейса. Пользователь думает, что нажимает на безопасную кнопку, но на самом деле совершает действие на реальном сайте — подтверждает покупку, изменяет настройки или передает данные. Именно из-за этого многие крупные сервисы намеренно запрещают отображение своих страниц во фреймах, минимизируя риск подобной подмены действий.\n\n#### *XSS через внешние фреймы*\n\nЕсли iFrame загружает непроверенный или потенциально опасный ресурс, внутри него может выполняться вредоносный JavaScript. В некоторых случаях такой скрипт способен попытаться взаимодействовать с родительской страницей, особенно если защита настроена неправильно. Это создает риск XSS-атак, фишинга, изменения DOM, перехвата данных пользователя. Проблема усиливается, когда фреймы используются без ограничений или разработчики доверяют внешним источникам без анализа безопасности.\n\n#### *Манипуляции с навигацией*\n\nНекорректно сконфигурированные iFrame могут изменять поведение браузера, перенаправлять пользователя на поддельные ресурсы или даже открывать всплывающие окна без его ведома. В прошлом такие атаки активно применялись мошенниками, чтобы уводить пользователей на фишинговые страницы или показывать рекламные баннеры. Именно поэтому защитные механизмы против таких действий были ужесточены на уровне браузеров, серверных настроек.\n\n## Механизмы защиты\n\n### sandbox\n\nАтрибут sandbox — один из самых эффективных способов защитить родительскую страницу от потенциально опасного содержимого во фрейме. Он создаёт строго ограниченную среду, где действия внешнего сайта контролируются, блокируются по умолчанию.\n\n```html\n<iframe src="..." sandbox="allow-scripts allow-forms"></iframe>\n```\n\nЕсли не указывать дополнительные разрешения:\n\n* **скрипты не смогут выполняться**,\n* **формы не будут отправляться**,\n* **клики по ссылкам не приведут к переходам**,\n* **доступ к большинству API браузера будет заблокирован**.\n\nТакой подход делает iFrame почти полностью безопасным, позволяет использовать его даже с незнакомым внешним контентом.\n\n### Content Security Policy (CSP)\n\nCSP даёт разработчику возможность контролировать, какие внешние ресурсы могут загружаться внутри сайта, его фреймов. С помощью директивы frame-src можно явно определить список доверенных доменов.\n\n```html\nframe-src https://trusted-domain.com;\n```\n\nЭто позволяет исключить загрузку непроверенных источников, предотвращает XSS-атаки и делает поведение iFrame предсказуемым. CSP — один из самых современных и гибких инструментов защиты.\n\n### X-Frame-Options\n\nНесмотря на то что этот механизм считается устаревшим, многие сайты по-прежнему используют его как дополнительный уровень защиты.\n\nЗаголовок:\n\n```html\nX-Frame-Options: SAMEORIGIN\n```\n\nзапрещает встраивание страницы в iFrame на других доменах. Это гарантирует, что злоумышленник не сможет открыть страницу на чужом сайте и использовать её для кликджекинга или скрытой подмены действий пользователя.\n\n## SEO и iFrame\n\nПоисковые системы относятся к содержимому, встроенному через iFrame, с большой осторожностью, это стоит учитывать при планировании SEO-стратегии. Для поисковиков iFrame чаще всего воспринимается как отдельный внешний элемент, не связанный напрямую с основным сайтом. Поэтому рассчитывать на то, что встроенный через него контент улучшит видимость ресурса в поиске, не приходится.\n\nПочему iFrame плохо влияет на продвижение:\n\n* **Контент внутри iFrame не считается частью вашего сайта.** Поисковые алгоритмы считают его принадлежащим исходному домену, а не странице, на которой он отображается.\n* **Он не индексируется как собственный текст.** Даже если внутри фрейма находится большая информационная статья, поисковики не учитывают её для ранжирования хоста — это всегда внешний ресурс.\n* **Поисковые роботы могут полностью игнорировать содержимое фрейма**, особенно если домен не разрешает индексирование или использует защитные заголовки.\n* **Ссылки внутри iFrame не передают ссылочный вес.** Это значит, что любые внешние ссылки, встроенные через фрейм, не учитываются в ссылочном профиле сайта и не помогают продвижению.\n\nПо этим причинам iFrame категорически не подходит для размещения важных текстов, SEO-статей, лендингов и другого контента, который должен участвовать в ранжировании. Использование фреймов для таких целей приведёт к потере позиций, снижению эффективности продвижения.\n\nТем не менее, для встраивания медиа, карт, платежных модулей, форм обратной связи, интерактивных сервисов iFrame остаётся полностью безопасным. Он не влияет на SEO в негативную сторону, поскольку такие элементы не предназначены для индексации и служат исключительно для улучшения функционала, удобства сайта.\n\n## Примеры использования iFrame\n\n### YouTube\n\n```html\n<iframe\n src="https://www.youtube.com/embed/VIDEO_ID"\n allow="autoplay; encrypted-media"\n allowfullscreen\n ></iframe>\n```\n\nВстраивание видео через YouTube стало стандартом благодаря удобству, универсальности iFrame. Такой способ позволяет разместить ролик на странице буквально за несколько секунд, без настройки дополнительных скриптов или модулей. Плеер автоматически подстраивается под размер контейнера, поддерживает разные форматы воспроизведения и остается полностью управляемым со стороны YouTube, что избавляет разработчиков от проблем с совместимостью, обновлениями.\n\n**Преимущества:**\n\n* быстрое внедрение даже для начинающих пользователей;\n* автоматическая адаптация под размер экрана, тип устройства;\n* официальный интерфейс с кнопками, настройками качества, подписями.\n\n### Google Maps\n\n```html\n<iframe\n src="https://www.google.com/maps/embed?pb=..."\n loading="lazy"\n></iframe>\n```\n\nВстраивание карт Google Maps через iFrame идеально подходит для сайтов, которым нужно показать посетителям локацию, маршруты или контактные данные компании. Такой вариант не требует настройки API и работает стабильно на всех устройствах. Он отлично подходит для страниц с адресами, профилей организаций, лендингов услуг, навигационных указателей.\n\n### Сторонние формы и сервисы\n\nЧерез iFrame можно встроить практически любые инструменты, требующие сохранения оригинального дизайна и поведения:\n\n* платежные виджеты;\n* квизы, интерактивные анкеты;\n* калькуляторы стоимости;\n* формы записи или заявок;\n* онлайн-чат или службу поддержки.\n\nТакой подход особенно удобен, когда сервисы предоставляют готовый embed-код. Это позволяет подключить функционал за минуты, без полноценной интеграции с API и сложной логики. Кроме того, iFrame изолирует внешний сервис от сайта, что повышает стабильность, предотвращает конфликты стилей, скриптов.\n\n## Альтернативы и современные подходы\n\n\n\nНесмотря на то что iFrame остаётся простым, универсальным и надежным инструментом, веб-разработка активно движется вперед, предлагая более гибкие и высокопроизводительные решения. Эти подходы позволяют избежать ограничений фреймов, ускорить загрузку страниц и повысить уровень безопасности при интеграции внешнего функционала.\n\n### API-интеграции\n\nAPI используют в тех случаях, когда требуется внедрить не готовый интерфейс, а только данные или логику. Такой метод позволяет максимально органично встроить функционал в структуру сайта, сохранив единый дизайн, поведение и UX.\n\nПреимущества API-интеграции:\n\n* динамический контент подгружается через JavaScript, что делает обновления незаметными, быстрыми;\n* сайт сохраняет собственную визуальную стилистику, контроль над разметкой;\n* это наиболее SEO-дружественный вариант, так как весь контент попадает в индекс поисковых систем;\n* архитектура остаётся гибкой, безопасной, легко масштабируемой.\n\nAPI — лучший выбор для сложных сервисов, систем с постоянными обновлениями, интерфейсов с высокой вариативностью и крупных проектов.\n\n### Web Components (Shadow DOM)\n\nТехнология Web Components позволяет создавать собственные элементы HTML, полностью изолированные от остальной разметки. Используя Shadow DOM, разработчики могут защищать стили и структуру компонента от влияния внешнего CSS и JavaScript.\n\nПреимущества:\n\n* полная защита от конфликтов CSS, глобальных стилей;\n* модульность интерфейса, что упрощает поддержку, повторное использование компонентов;\n* высокая скорость работы за счёт нативной поддержки браузерами;\n* возможность создавать масштабируемые systems design-библиотеки.\n\nФактически Web Components становятся «iFrame нового поколения», сохраняя изоляцию, но предлагая гораздо более плавную интеграцию, контроль.\n\n### Скриптовые виджеты\n\nМногие сервисы создают embed-коды на основе обычного:\n\n```html\n<script src="..."></script>\n```\n\nПри подключении такого скрипта мини-приложение рендерится прямо внутри страницы, но без использования iFrame. Это экономит ресурсы и позволяет детальнее контролировать внешний вид, поведение виджета.\n\nПреимущества скриптовых виджетов:\n\n* высокая производительность;\n* отсутствие лишней изоляции;\n* гибкость интеграции;\n* легкость обновления функционала поставщиком.\n\n## Тренды и развитие\n\nСовременные технологии активно меняют подход к использованию iFrame. Хотя фреймы продолжают оставаться полезным инструментом, их роль постепенно сдвигается в сторону более специализированных и ограниченных сценариев.\n\n### iFrame в SPA\n\nВ одностраничных приложениях (SPA) iFrame применяется точечно, в основном как:\n\n* внешняя часть микросервиса,\n* безопасная среда для платёжных форм,\n* временная зона для подключения нестандартных интеграций.\n\nЗа счёт изоляции он помогает соблюдать требования безопасности и защищать ключевые части приложения.\n\n### Ограничение сторонних ресурсов\n\nРост внимания к приватности, безопасности данных повлиял на работу iFrame:\n\n* cookies внутри iFrame всё чаще становятся недоступными из-за строгих правил браузеров;\n* для некоторых сценариев требуется явное согласие пользователя;\n* многие сторонние ресурсы блокируются, если не соответствуют политикам безопасности.\n\nЭто усложняет внедрение старых решений, но делает веб-среду безопаснее, предсказуемее.\n\n### Рост микрофронтендов\n\nСовременные компании все чаще переходят на архитектуру микрофронтендов. Интерфейс собирается из независимых модулей, каждый из которых может быть создан и обновлён отдельной командой. В некоторых случаях такие модули изолируются внутри iFrame, чтобы:\n\n* избежать конфликтов стилей,\n* обеспечить устойчивую работу,\n* разделить ответственность между командами.\n\nТакой подход помогает масштабировать большие проекты, упрощает управление сложными интерфейсами.\n\n## Заключение\n\niFrame — это простая и надежная технология, которая остается актуальной несмотря на быстрый рост современных веб-решений. Он позволяет быстро внедрять внешний функционал, обеспечивать изоляцию, интегрировать сложные сервисы без переписывания кода. Однако использование iFrame требует понимания его ограничений — прежде всего в вопросах безопасности и SEO.\n\nСегодня iFrame часто применяется в связке с API, web-компонентами и SPA-архитектурой, дополняя новые подходы, обеспечивая удобную интеграцию сторонних интерфейсов.\n","datePublished":"2025-12-18T18:02:38.406Z","upvoteCount":1,"author":{"@type":"Person","name":"Nikolai Gagarinov"},"url":"https://ru.hexlet.io/qna/glossary/questions/chto-takoe-iframe#answer-5354"},"suggestedAnswer":[{"@type":"Answer","text":"iFrame - это элемент HTML, который позволяет встраивать содержимое одного документа в другой. Он создается с помощью тега <iframe> и содержит содержимое, указанное в атрибуте src. iFrame может использоваться для отображения содержимого других веб-страниц или документов внутри текущего документа, что позволяет создавать сложные веб-страницы с интегрированным содержимым из разных источников.","datePublished":"2023-11-16T18:59:50.101Z","upvoteCount":0,"author":{"@type":"Person","name":"Елена Редькина"},"url":"https://ru.hexlet.io/qna/glossary/questions/chto-takoe-iframe#answer-3237"}]}}</script><div style="--container-size:var(--container-size-lg);margin-top:var(--mantine-spacing-xl);height:100%" class="m_7485cace mantine-Container-root" data-size="lg" data-strategy="block"><script type="application/ld+json">{"@context":"https://schema.org","@type":"BreadcrumbList","itemListElement":[{"position":1,"@type":"ListItem","item":{"@id":"/qna","name":"Вопросы и ответы"}},{"position":2,"@type":"ListItem","item":{"@id":"/qna/glossary/questions","name":"Глоссарий"}},{"position":3,"@type":"ListItem","item":{"@id":"/qna/glossary/questions/chto-takoe-iframe","name":"iFrame"}}]}</script><div style="margin-bottom:var(--mantine-spacing-xs)" class="m_8b3717df mantine-Breadcrumbs-root"><a style="--text-fz:var(--mantine-font-size-sm);--text-lh:var(--mantine-line-height-sm);white-space:normal;color:inherit" class="mantine-focus-auto m_849cf0da m_f678d540 mantine-Breadcrumbs-breadcrumb m_b6d8b162 mantine-Text-root mantine-Anchor-root" data-size="sm" data-underline="hover" href="/"><div style="color:inherit" class="m_4451eb3a mantine-Center-root"><svg xmlns="http://www.w3.org/2000/svg" width="15" height="15" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2" stroke-linecap="round" stroke-linejoin="round" class="tabler-icon tabler-icon-home-link "><path d="M20.085 11.085l-8.085 -8.085l-9 9h2v7a2 2 0 0 0 2 2h4.5"></path><path d="M9 21v-6a2 2 0 0 1 2 -2h2a2 2 0 0 1 1.807 1.143"></path><path d="M20 21a1 1 0 1 0 2 0a1 1 0 1 0 -2 0"></path><path d="M20 16a1 1 0 1 0 2 0a1 1 0 1 0 -2 0"></path><path d="M15 19a1 1 0 1 0 2 0a1 1 0 1 0 -2 0"></path><path d="M21 16l-5 3l5 2"></path></svg></div></a><div class="m_3b8f2208 mantine-Breadcrumbs-separator">/</div><a style="--text-fz:var(--mantine-font-size-sm);--text-lh:var(--mantine-line-height-sm);white-space:normal;color:inherit" class="mantine-focus-auto m_849cf0da m_f678d540 mantine-Breadcrumbs-breadcrumb m_b6d8b162 mantine-Text-root mantine-Anchor-root" data-size="sm" data-underline="hover" href="/qna">Вопросы и ответы</a><div class="m_3b8f2208 mantine-Breadcrumbs-separator">/</div><a style="--text-fz:var(--mantine-font-size-sm);--text-lh:var(--mantine-line-height-sm);white-space:normal;color:inherit" class="mantine-focus-auto m_849cf0da m_f678d540 mantine-Breadcrumbs-breadcrumb m_b6d8b162 mantine-Text-root mantine-Anchor-root" data-size="sm" data-underline="hover" href="/qna/glossary/questions">Глоссарий</a><div class="m_3b8f2208 mantine-Breadcrumbs-separator">/</div><p style="--text-fz:var(--mantine-font-size-sm);--text-lh:var(--mantine-line-height-sm);white-space:normal;color:var(--mantine-color-dimmed)" class="mantine-focus-auto m_f678d540 mantine-Breadcrumbs-breadcrumb m_b6d8b162 mantine-Text-root" data-size="sm">iFrame</p></div><style data-mantine-styles="inline">.__m__-_R_eub_{margin-bottom:var(--mantine-spacing-xs);}@media(min-width: 36em){.__m__-_R_eub_{margin-bottom:var(--mantine-spacing-xs);}}</style><div style="--group-gap:var(--mantine-spacing-md);--group-align:center;--group-justify:space-between;--group-wrap:wrap" class="m_4081bf90 mantine-Group-root __m__-_R_eub_"><style data-mantine-styles="inline">.__m__-_R_deub_{width:100%;}@media(min-width: 36em){.__m__-_R_deub_{width:70%;}}@media(min-width: 75em){.__m__-_R_deub_{width:75%;}}</style><div class="__m__-_R_deub_"><div style="--group-gap:var(--mantine-spacing-md);--group-align:center;--group-justify:start;--group-wrap:nowrap" class="m_4081bf90 mantine-Group-root"><h1 style="--title-fw:var(--mantine-h1-font-weight);--title-lh:var(--mantine-h1-line-height);--title-fz:var(--mantine-h1-font-size)" class="m_8a5d1357 mantine-Title-root" data-order="1">iFrame</h1></div></div></div><style data-mantine-styles="inline">.__m__-_R_iub_{--grid-gutter:var(--mantine-spacing-md);}</style><div class="m_410352e9 mantine-Grid-root __m__-_R_iub_"><div class="m_dee7bd2f mantine-Grid-inner"><style data-mantine-styles="inline">.__m__-_R_3diub_{--col-flex-grow:auto;--col-flex-basis:100%;--col-max-width:100%;}@media(min-width: 48em){.__m__-_R_3diub_{--col-flex-grow:auto;--col-flex-basis:83.33333333333334%;--col-max-width:83.33333333333334%;}}@media(min-width: 62em){.__m__-_R_3diub_{--col-flex-grow:auto;--col-flex-basis:66.66666666666667%;--col-max-width:66.66666666666667%;}}</style><div class="m_96bdd299 mantine-Grid-col __m__-_R_3diub_"><div style="--group-gap:var(--mantine-spacing-md);--group-align:center;--group-justify:flex-start;--group-wrap:wrap;margin-bottom:var(--mantine-spacing-lg)" class="m_4081bf90 mantine-Group-root"></div><div style="--group-gap:var(--mantine-spacing-md);--group-align:center;--group-justify:flex-start;--group-wrap:wrap;margin-bottom:var(--mantine-spacing-xl);font-size:var(--mantine-font-size-sm)" class="m_4081bf90 mantine-Group-root"><div style="--group-gap:calc(0.25rem * var(--mantine-scale));--group-align:center;--group-justify:flex-start;--group-wrap:wrap;margin-inline-start:auto" class="m_4081bf90 mantine-Group-root"><svg xmlns="http://www.w3.org/2000/svg" width="16" height="16" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2" stroke-linecap="round" stroke-linejoin="round" class="tabler-icon tabler-icon-calendar "><path d="M4 7a2 2 0 0 1 2 -2h12a2 2 0 0 1 2 2v12a2 2 0 0 1 -2 2h-12a2 2 0 0 1 -2 -2v-12"></path><path d="M16 3v4"></path><path d="M8 3v4"></path><path d="M4 11h16"></path><path d="M11 15h1"></path><path d="M12 15v3"></path></svg><p class="mantine-focus-auto m_b6d8b162 mantine-Text-root" data-inherit="true">3 года назад</p></div><div style="--group-gap:calc(0.25rem * var(--mantine-scale));--group-align:center;--group-justify:flex-start;--group-wrap:wrap" class="m_4081bf90 mantine-Group-root"><svg xmlns="http://www.w3.org/2000/svg" width="16" height="16" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2" stroke-linecap="round" stroke-linejoin="round" class="tabler-icon tabler-icon-user "><path d="M8 7a4 4 0 1 0 8 0a4 4 0 0 0 -8 0"></path><path d="M6 21v-2a4 4 0 0 1 4 -4h4a4 4 0 0 1 4 4v2"></path></svg><p class="mantine-focus-auto m_b6d8b162 mantine-Text-root" data-inherit="true">Nikolai Gagarinov</p></div></div><div role="link" tabindex="0" style="cursor:pointer"><button style="display:block;width:100%" class="mantine-focus-auto m_87cf2631 mantine-UnstyledButton-root" type="button" aria-label="Присоединяйтесь к нашему Telegram-сообществу"><div style="background-color:light-dark(var(--mantine-color-gray-1), var(--mantine-color-dark-6));margin-block:var(--mantine-spacing-xs)" class="m_e615b15f mantine-Card-root m_1b7284a3 mantine-Paper-root"><div style="--group-gap:var(--mantine-spacing-md);--group-align:center;--group-justify:flex-start;--group-wrap:wrap" class="m_4081bf90 mantine-Group-root"><div style="--ti-bg:transparent;--ti-color:var(--mantine-color-indigo-light-color);--ti-bd:calc(0.0625rem * var(--mantine-scale)) solid transparent;margin-inline-end:auto;color:inherit" class="m_7341320d mantine-ThemeIcon-root" data-variant="transparent"><svg xmlns="http://www.w3.org/2000/svg" width="24" height="24" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="1.2" stroke-linecap="round" stroke-linejoin="round" class="tabler-icon tabler-icon-brand-telegram "><path d="M15 10l-4 4l6 6l4 -16l-18 7l4 2l2 6l3 -4"></path></svg></div>Присоединяйтесь к нашему Telegram-сообществу</div></div></button></div><h2 style="--title-fw:var(--mantine-h2-font-weight);--title-lh:var(--mantine-h2-line-height);--title-fz:var(--mantine-h2-font-size);margin-block:var(--mantine-spacing-xl)" class="m_8a5d1357 mantine-Title-root" data-order="2">Ответы</h2><div style="margin-bottom:var(--mantine-spacing-xl);padding:var(--mantine-spacing-lg)" class="m_e615b15f mantine-Card-root m_1b7284a3 mantine-Paper-root" data-with-border="true" id="answer-5354"><div style="--group-gap:calc(1.125rem * var(--mantine-scale));--group-align:stretch;--group-justify:flex-start;--group-wrap:nowrap" class="m_4081bf90 mantine-Group-root"><div style="--stack-gap:var(--mantine-spacing-md);--stack-align:stretch;--stack-justify:flex-start;font-size:var(--mantine-font-size-h1);font-weight:lighter;text-align:center" class="m_6d731127 mantine-Stack-root">1<a style="color:inherit" class="mantine-focus-auto m_849cf0da m_b6d8b162 mantine-Text-root mantine-Anchor-root" data-underline="hover" href="/qna/glossary/questions/chto-takoe-iframe/answers/5354/vote"><div style="--ti-bg:transparent;--ti-color:var(--mantine-color-indigo-light-color);--ti-bd:calc(0.0625rem * var(--mantine-scale)) solid transparent;color:inherit" class="m_7341320d mantine-ThemeIcon-root" data-variant="transparent"><svg xmlns="http://www.w3.org/2000/svg" width="24" height="24" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2" stroke-linecap="round" stroke-linejoin="round" class="tabler-icon tabler-icon-thumb-up "><path d="M7 11v8a1 1 0 0 1 -1 1h-2a1 1 0 0 1 -1 -1v-7a1 1 0 0 1 1 -1h3a4 4 0 0 0 4 -4v-1a2 2 0 0 1 4 0v5h3a2 2 0 0 1 2 2l-1 5a2 3 0 0 1 -2 2h-7a3 3 0 0 1 -3 -3"></path></svg></div></a><div style="--ti-bg:transparent;--ti-color:var(--mantine-color-indigo-light-color);--ti-bd:calc(0.0625rem * var(--mantine-scale)) solid transparent;color:inherit" class="m_7341320d mantine-ThemeIcon-root" data-variant="transparent"><svg xmlns="http://www.w3.org/2000/svg" width="24" height="24" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2" stroke-linecap="round" stroke-linejoin="round" class="tabler-icon tabler-icon-check "><path d="M5 12l5 5l10 -10"></path></svg></div></div><div style="--stack-gap:var(--mantine-spacing-md);--stack-align:stretch;--stack-justify:flex-start;width:100%;min-width:0rem" class="m_6d731127 mantine-Stack-root"><div style="margin-bottom:auto" class="m_d08caa0 mantine-Typography-root"><p>Элемент <strong>iFrame</strong> уже много лет остаётся одной из ключевых технологий для встраивания внешнего контента на веб-страницы. Он позволяет отображать внутри сайта независимую страницу или приложение, фактически создавая автономное окно, которое существует отдельно от основного DOM. Такая изоляция делает iFrame удобным инструментом для интеграции сервисов, не требующих глубокого взаимодействия с сайтом-хостом. Несмотря на активное развитие API-интеграций, web-компонентов и других современных техник, iFrame продолжает широко использоваться благодаря своей универсальности, простоте внедрения, кроссбраузерной стабильности.</p>
<p><img style="--image-object-fit:contain;width:auto" class="m_9e117634 mantine-Image-root" src="https://cdn6.hexlet.io/qaEH9Cc68SaF.png" alt="" loading="lazy"/></p>
<h2 id="heading-2-1">Определение и назначение</h2>
<p><strong>iFrame (inline frame)</strong> — это HTML-элемент, позволяющий встроить одну веб-страницу в другую, при этом обеспечивая четкое разграничение контентных областей. Он загружает внешний документ в собственный изолированный контекст браузера, что делает его своеобразной «песочницей» для размещения стороннего функционала.</p>
<p>Базовый пример синтаксиса:</p>
<div style="margin-bottom:var(--mantine-spacing-lg)" class="m_e597c321 mantine-CodeHighlight-codeHighlight" dir="ltr"><div class="m_be7e9c9c mantine-CodeHighlight-controls"><button style="--ai-bg:transparent;--ai-hover:transparent;--ai-color:inherit;--ai-bd:none" class="mantine-focus-auto mantine-active m_d498bab7 mantine-CodeHighlight-control m_8d3f4000 mantine-ActionIcon-root m_87cf2631 mantine-UnstyledButton-root" data-variant="none" type="button" aria-label="Copy code"><span class="m_8d3afb97 mantine-ActionIcon-icon"><svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24" stroke-width="2" stroke="currentColor" fill="none" stroke-linecap="round" stroke-linejoin="round"><path stroke="none" d="M0 0h24v24H0z" fill="none"></path><path d="M8 8m0 2a2 2 0 0 1 2 -2h8a2 2 0 0 1 2 2v8a2 2 0 0 1 -2 2h-8a2 2 0 0 1 -2 -2z"></path><path d="M16 8v-2a2 2 0 0 0 -2 -2h-8a2 2 0 0 0 -2 2v8a2 2 0 0 0 2 2h2"></path></svg></span></button></div><div style="--scrollarea-scrollbar-size:calc(0.25rem * var(--mantine-scale));--sa-corner-width:0px;--sa-corner-height:0px" class="m_f744fd40 mantine-CodeHighlight-scrollarea m_d57069b5 mantine-ScrollArea-root" dir="ltr"><div style="overflow-x:hidden;overflow-y:hidden;overscroll-behavior-inline:none" class="m_c0783ff9 mantine-ScrollArea-viewport" data-scrollbars="xy"><div class="m_b1336c6 mantine-ScrollArea-content"><pre class="m_2c47c4fd mantine-CodeHighlight-pre" style="padding:0"><code class="m_5caae6d3 mantine-CodeHighlight-code"><iframe src="https://example.com" width="600" height="400"></iframe></code></pre></div></div></div><button class="mantine-focus-auto m_c9378bc2 mantine-CodeHighlight-showCodeButton m_87cf2631 mantine-UnstyledButton-root" data-hidden="true" type="button">Expand code</button></div>
<p>Этот элемент остается незаменимым для разработчиков, которым нужно быстро внедрить внешний функционал без сложных интеграций. В отличие от <code style="margin-bottom:var(--mantine-spacing-lg)" class="m_dfe9c588 mantine-InlineCodeHighlight-inlineCodeHighlight m_e597c321 mantine-CodeHighlight-codeHighlight m_dfe9c588 mantine-InlineCodeHighlight-inlineCodeHighlight"><embed></code> или <code style="margin-bottom:var(--mantine-spacing-lg)" class="m_dfe9c588 mantine-InlineCodeHighlight-inlineCodeHighlight m_e597c321 mantine-CodeHighlight-codeHighlight m_dfe9c588 mantine-InlineCodeHighlight-inlineCodeHighlight"><object></code>, iFrame обладает более стабильной структурой отображения и гибкими настройками поведения.</p>
<p>С его помощью можно решать задачи разной сложности — от простого встраивания видео до размещения целых внешних приложений. Именно поэтому iFrame до сих пор широко используется в маркетинге, аналитике, e-commerce, обучающих платформах и корпоративных системах.</p>
<h2 id="heading-2-2">Применение iFrame</h2>
<p>Область применения iFrame чрезвычайно широкая, особенно в ситуациях, когда требуется встроить сторонний контент, не адаптируя его под стилистику или архитектуру сайта. Такой подход позволяет сохранить неизменным внешний вид и поведение внешнего ресурса, что особенно важно при работе с сервисами, которые должны выглядеть и функционировать одинаково на всех площадках. Благодаря изоляции фрейма и отсутствию конфликтов с хост-страницей, iFrame остается удобным инструментом для размещения готовых решений.</p>
<h3 id="heading-3-3">Встраивание мультимедиа</h3>
<p>iFrame стал стандартным способом размещения видеоплееров, презентаций, прямых трансляций и других медиаформатов. Платформы вроде YouTube, Vimeo, Rutube и образовательные сервисы используют именно этот подход, поскольку он обеспечивает стабильную работу плеера, защиту контента, независимость от стилей сайта. Такое решение позволяет сохранять полный контроль над воспроизведением, рекламными вставками, субтитрами и статистикой просмотров, не перегружая основной проект лишним функционалом.</p>
<h3 id="heading-3-4">Интерактивные карты</h3>
<p>Современные картографические сервисы предоставляют готовые embed-виджеты, идеально работающие именно в iFrame. Благодаря этому сайты могут легко отображать схемы проезда, геолокацию, панорамы улиц, маршруты и геоданные без необходимости подключать сложные API. Такой подход особенно выгоден небольшим проектам, которым не нужна собственная логика работы карты: достаточно вставить код, настроить размер фрейма.</p>
<h3 id="heading-3-5">Внедрение сторонних сервисов</h3>
<p>Через iFrame можно встроить практически любой сервис, интерфейс которого должен сохраняться полностью:</p>
<ul>
<li>формы бронирования;</li>
<li>CRM-виджеты для записи или обработки заявок;</li>
<li>платежные системы и кнопки;</li>
<li>окна онлайн-консультантов;</li>
<li>интерактивные калькуляторы, тесты.</li>
</ul>
<p>Поставщикам услуг удобно предоставлять именно формат iFrame, так как он гарантирует, что их продукт будет отображаться одинаково на всех сайтах, а внутренние стили, скрипты не вступят в конфликт с кодом площадки.</p>
<h3 id="heading-3-6">Вывод независимого или потенциально опасного контента</h3>
<p>В ситуациях, когда требуется показать стороннюю страницу, содержащую нестабильный код, экспериментальную функциональность или административную панель, iFrame обеспечивает надежную изоляцию. Он создаёт отдельный контекст выполнения, не позволяя внешнему скрипту вмешиваться в работу основного сайта. Это делает фрейм удобным инструментом для тестирования, интеграции мониторинговых панелей или размещения контента, который может нарушить структуру основной страницы.</p>
<h2 id="heading-2-7">Безопасность iFrame</h2>
<p>iFrame часто рассматривается как потенциально опасный инструмент, если используется неправильно. Он действительно может создавать уязвимости, но современные стандарты позволяют значительно снизить риски.</p>
<h3 id="heading-3-8">Основные угрозы</h3>
<h4 id="heading-4-9"><em>Кликджекинг</em></h4>
<p>Кликджекинг — одна из самых известных атак, связанных с iFrame. Ее суть заключается в том, что злоумышленник незаметно встраивает чужой сайт в прозрачный или маскированный iFrame и накладывает поверх него собственные элементы интерфейса. Пользователь думает, что нажимает на безопасную кнопку, но на самом деле совершает действие на реальном сайте — подтверждает покупку, изменяет настройки или передает данные. Именно из-за этого многие крупные сервисы намеренно запрещают отображение своих страниц во фреймах, минимизируя риск подобной подмены действий.</p>
<h4 id="heading-4-10"><em>XSS через внешние фреймы</em></h4>
<p>Если iFrame загружает непроверенный или потенциально опасный ресурс, внутри него может выполняться вредоносный JavaScript. В некоторых случаях такой скрипт способен попытаться взаимодействовать с родительской страницей, особенно если защита настроена неправильно. Это создает риск XSS-атак, фишинга, изменения DOM, перехвата данных пользователя. Проблема усиливается, когда фреймы используются без ограничений или разработчики доверяют внешним источникам без анализа безопасности.</p>
<h4 id="heading-4-11"><em>Манипуляции с навигацией</em></h4>
<p>Некорректно сконфигурированные iFrame могут изменять поведение браузера, перенаправлять пользователя на поддельные ресурсы или даже открывать всплывающие окна без его ведома. В прошлом такие атаки активно применялись мошенниками, чтобы уводить пользователей на фишинговые страницы или показывать рекламные баннеры. Именно поэтому защитные механизмы против таких действий были ужесточены на уровне браузеров, серверных настроек.</p>
<h2 id="heading-2-12">Механизмы защиты</h2>
<h3 id="heading-3-13">sandbox</h3>
<p>Атрибут sandbox — один из самых эффективных способов защитить родительскую страницу от потенциально опасного содержимого во фрейме. Он создаёт строго ограниченную среду, где действия внешнего сайта контролируются, блокируются по умолчанию.</p>
<div style="margin-bottom:var(--mantine-spacing-lg)" class="m_e597c321 mantine-CodeHighlight-codeHighlight" dir="ltr"><div class="m_be7e9c9c mantine-CodeHighlight-controls"><button style="--ai-bg:transparent;--ai-hover:transparent;--ai-color:inherit;--ai-bd:none" class="mantine-focus-auto mantine-active m_d498bab7 mantine-CodeHighlight-control m_8d3f4000 mantine-ActionIcon-root m_87cf2631 mantine-UnstyledButton-root" data-variant="none" type="button" aria-label="Copy code"><span class="m_8d3afb97 mantine-ActionIcon-icon"><svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24" stroke-width="2" stroke="currentColor" fill="none" stroke-linecap="round" stroke-linejoin="round"><path stroke="none" d="M0 0h24v24H0z" fill="none"></path><path d="M8 8m0 2a2 2 0 0 1 2 -2h8a2 2 0 0 1 2 2v8a2 2 0 0 1 -2 2h-8a2 2 0 0 1 -2 -2z"></path><path d="M16 8v-2a2 2 0 0 0 -2 -2h-8a2 2 0 0 0 -2 2v8a2 2 0 0 0 2 2h2"></path></svg></span></button></div><div style="--scrollarea-scrollbar-size:calc(0.25rem * var(--mantine-scale));--sa-corner-width:0px;--sa-corner-height:0px" class="m_f744fd40 mantine-CodeHighlight-scrollarea m_d57069b5 mantine-ScrollArea-root" dir="ltr"><div style="overflow-x:hidden;overflow-y:hidden;overscroll-behavior-inline:none" class="m_c0783ff9 mantine-ScrollArea-viewport" data-scrollbars="xy"><div class="m_b1336c6 mantine-ScrollArea-content"><pre class="m_2c47c4fd mantine-CodeHighlight-pre" style="padding:0"><code class="m_5caae6d3 mantine-CodeHighlight-code"><iframe src="..." sandbox="allow-scripts allow-forms"></iframe></code></pre></div></div></div><button class="mantine-focus-auto m_c9378bc2 mantine-CodeHighlight-showCodeButton m_87cf2631 mantine-UnstyledButton-root" data-hidden="true" type="button">Expand code</button></div>
<p>Если не указывать дополнительные разрешения:</p>
<ul>
<li><strong>скрипты не смогут выполняться</strong>,</li>
<li><strong>формы не будут отправляться</strong>,</li>
<li><strong>клики по ссылкам не приведут к переходам</strong>,</li>
<li><strong>доступ к большинству API браузера будет заблокирован</strong>.</li>
</ul>
<p>Такой подход делает iFrame почти полностью безопасным, позволяет использовать его даже с незнакомым внешним контентом.</p>
<h3 id="heading-3-14">Content Security Policy (CSP)</h3>
<p>CSP даёт разработчику возможность контролировать, какие внешние ресурсы могут загружаться внутри сайта, его фреймов. С помощью директивы frame-src можно явно определить список доверенных доменов.</p>
<div style="margin-bottom:var(--mantine-spacing-lg)" class="m_e597c321 mantine-CodeHighlight-codeHighlight" dir="ltr"><div class="m_be7e9c9c mantine-CodeHighlight-controls"><button style="--ai-bg:transparent;--ai-hover:transparent;--ai-color:inherit;--ai-bd:none" class="mantine-focus-auto mantine-active m_d498bab7 mantine-CodeHighlight-control m_8d3f4000 mantine-ActionIcon-root m_87cf2631 mantine-UnstyledButton-root" data-variant="none" type="button" aria-label="Copy code"><span class="m_8d3afb97 mantine-ActionIcon-icon"><svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24" stroke-width="2" stroke="currentColor" fill="none" stroke-linecap="round" stroke-linejoin="round"><path stroke="none" d="M0 0h24v24H0z" fill="none"></path><path d="M8 8m0 2a2 2 0 0 1 2 -2h8a2 2 0 0 1 2 2v8a2 2 0 0 1 -2 2h-8a2 2 0 0 1 -2 -2z"></path><path d="M16 8v-2a2 2 0 0 0 -2 -2h-8a2 2 0 0 0 -2 2v8a2 2 0 0 0 2 2h2"></path></svg></span></button></div><div style="--scrollarea-scrollbar-size:calc(0.25rem * var(--mantine-scale));--sa-corner-width:0px;--sa-corner-height:0px" class="m_f744fd40 mantine-CodeHighlight-scrollarea m_d57069b5 mantine-ScrollArea-root" dir="ltr"><div style="overflow-x:hidden;overflow-y:hidden;overscroll-behavior-inline:none" class="m_c0783ff9 mantine-ScrollArea-viewport" data-scrollbars="xy"><div class="m_b1336c6 mantine-ScrollArea-content"><pre class="m_2c47c4fd mantine-CodeHighlight-pre" style="padding:0"><code class="m_5caae6d3 mantine-CodeHighlight-code">frame-src https://trusted-domain.com;</code></pre></div></div></div><button class="mantine-focus-auto m_c9378bc2 mantine-CodeHighlight-showCodeButton m_87cf2631 mantine-UnstyledButton-root" data-hidden="true" type="button">Expand code</button></div>
<p>Это позволяет исключить загрузку непроверенных источников, предотвращает XSS-атаки и делает поведение iFrame предсказуемым. CSP — один из самых современных и гибких инструментов защиты.</p>
<h3 id="heading-3-15">X-Frame-Options</h3>
<p>Несмотря на то что этот механизм считается устаревшим, многие сайты по-прежнему используют его как дополнительный уровень защиты.</p>
<p>Заголовок:</p>
<div style="margin-bottom:var(--mantine-spacing-lg)" class="m_e597c321 mantine-CodeHighlight-codeHighlight" dir="ltr"><div class="m_be7e9c9c mantine-CodeHighlight-controls"><button style="--ai-bg:transparent;--ai-hover:transparent;--ai-color:inherit;--ai-bd:none" class="mantine-focus-auto mantine-active m_d498bab7 mantine-CodeHighlight-control m_8d3f4000 mantine-ActionIcon-root m_87cf2631 mantine-UnstyledButton-root" data-variant="none" type="button" aria-label="Copy code"><span class="m_8d3afb97 mantine-ActionIcon-icon"><svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24" stroke-width="2" stroke="currentColor" fill="none" stroke-linecap="round" stroke-linejoin="round"><path stroke="none" d="M0 0h24v24H0z" fill="none"></path><path d="M8 8m0 2a2 2 0 0 1 2 -2h8a2 2 0 0 1 2 2v8a2 2 0 0 1 -2 2h-8a2 2 0 0 1 -2 -2z"></path><path d="M16 8v-2a2 2 0 0 0 -2 -2h-8a2 2 0 0 0 -2 2v8a2 2 0 0 0 2 2h2"></path></svg></span></button></div><div style="--scrollarea-scrollbar-size:calc(0.25rem * var(--mantine-scale));--sa-corner-width:0px;--sa-corner-height:0px" class="m_f744fd40 mantine-CodeHighlight-scrollarea m_d57069b5 mantine-ScrollArea-root" dir="ltr"><div style="overflow-x:hidden;overflow-y:hidden;overscroll-behavior-inline:none" class="m_c0783ff9 mantine-ScrollArea-viewport" data-scrollbars="xy"><div class="m_b1336c6 mantine-ScrollArea-content"><pre class="m_2c47c4fd mantine-CodeHighlight-pre" style="padding:0"><code class="m_5caae6d3 mantine-CodeHighlight-code">X-Frame-Options: SAMEORIGIN</code></pre></div></div></div><button class="mantine-focus-auto m_c9378bc2 mantine-CodeHighlight-showCodeButton m_87cf2631 mantine-UnstyledButton-root" data-hidden="true" type="button">Expand code</button></div>
<p>запрещает встраивание страницы в iFrame на других доменах. Это гарантирует, что злоумышленник не сможет открыть страницу на чужом сайте и использовать её для кликджекинга или скрытой подмены действий пользователя.</p>
<h2 id="heading-2-16">SEO и iFrame</h2>
<p>Поисковые системы относятся к содержимому, встроенному через iFrame, с большой осторожностью, это стоит учитывать при планировании SEO-стратегии. Для поисковиков iFrame чаще всего воспринимается как отдельный внешний элемент, не связанный напрямую с основным сайтом. Поэтому рассчитывать на то, что встроенный через него контент улучшит видимость ресурса в поиске, не приходится.</p>
<p>Почему iFrame плохо влияет на продвижение:</p>
<ul>
<li><strong>Контент внутри iFrame не считается частью вашего сайта.</strong> Поисковые алгоритмы считают его принадлежащим исходному домену, а не странице, на которой он отображается.</li>
<li><strong>Он не индексируется как собственный текст.</strong> Даже если внутри фрейма находится большая информационная статья, поисковики не учитывают её для ранжирования хоста — это всегда внешний ресурс.</li>
<li><strong>Поисковые роботы могут полностью игнорировать содержимое фрейма</strong>, особенно если домен не разрешает индексирование или использует защитные заголовки.</li>
<li><strong>Ссылки внутри iFrame не передают ссылочный вес.</strong> Это значит, что любые внешние ссылки, встроенные через фрейм, не учитываются в ссылочном профиле сайта и не помогают продвижению.</li>
</ul>
<p>По этим причинам iFrame категорически не подходит для размещения важных текстов, SEO-статей, лендингов и другого контента, который должен участвовать в ранжировании. Использование фреймов для таких целей приведёт к потере позиций, снижению эффективности продвижения.</p>
<p>Тем не менее, для встраивания медиа, карт, платежных модулей, форм обратной связи, интерактивных сервисов iFrame остаётся полностью безопасным. Он не влияет на SEO в негативную сторону, поскольку такие элементы не предназначены для индексации и служат исключительно для улучшения функционала, удобства сайта.</p>
<h2 id="heading-2-17">Примеры использования iFrame</h2>
<h3 id="heading-3-18">YouTube</h3>
<div style="margin-bottom:var(--mantine-spacing-lg)" class="m_e597c321 mantine-CodeHighlight-codeHighlight" dir="ltr"><div class="m_be7e9c9c mantine-CodeHighlight-controls"><button style="--ai-bg:transparent;--ai-hover:transparent;--ai-color:inherit;--ai-bd:none" class="mantine-focus-auto mantine-active m_d498bab7 mantine-CodeHighlight-control m_8d3f4000 mantine-ActionIcon-root m_87cf2631 mantine-UnstyledButton-root" data-variant="none" type="button" aria-label="Copy code"><span class="m_8d3afb97 mantine-ActionIcon-icon"><svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24" stroke-width="2" stroke="currentColor" fill="none" stroke-linecap="round" stroke-linejoin="round"><path stroke="none" d="M0 0h24v24H0z" fill="none"></path><path d="M8 8m0 2a2 2 0 0 1 2 -2h8a2 2 0 0 1 2 2v8a2 2 0 0 1 -2 2h-8a2 2 0 0 1 -2 -2z"></path><path d="M16 8v-2a2 2 0 0 0 -2 -2h-8a2 2 0 0 0 -2 2v8a2 2 0 0 0 2 2h2"></path></svg></span></button></div><div style="--scrollarea-scrollbar-size:calc(0.25rem * var(--mantine-scale));--sa-corner-width:0px;--sa-corner-height:0px" class="m_f744fd40 mantine-CodeHighlight-scrollarea m_d57069b5 mantine-ScrollArea-root" dir="ltr"><div style="overflow-x:hidden;overflow-y:hidden;overscroll-behavior-inline:none" class="m_c0783ff9 mantine-ScrollArea-viewport" data-scrollbars="xy"><div class="m_b1336c6 mantine-ScrollArea-content"><pre class="m_2c47c4fd mantine-CodeHighlight-pre" style="padding:0"><code class="m_5caae6d3 mantine-CodeHighlight-code"><iframe
src="https://www.youtube.com/embed/VIDEO_ID"
allow="autoplay; encrypted-media"
allowfullscreen
></iframe></code></pre></div></div></div><button class="mantine-focus-auto m_c9378bc2 mantine-CodeHighlight-showCodeButton m_87cf2631 mantine-UnstyledButton-root" data-hidden="true" type="button">Expand code</button></div>
<p>Встраивание видео через YouTube стало стандартом благодаря удобству, универсальности iFrame. Такой способ позволяет разместить ролик на странице буквально за несколько секунд, без настройки дополнительных скриптов или модулей. Плеер автоматически подстраивается под размер контейнера, поддерживает разные форматы воспроизведения и остается полностью управляемым со стороны YouTube, что избавляет разработчиков от проблем с совместимостью, обновлениями.</p>
<p><strong>Преимущества:</strong></p>
<ul>
<li>быстрое внедрение даже для начинающих пользователей;</li>
<li>автоматическая адаптация под размер экрана, тип устройства;</li>
<li>официальный интерфейс с кнопками, настройками качества, подписями.</li>
</ul>
<h3 id="heading-3-19">Google Maps</h3>
<div style="margin-bottom:var(--mantine-spacing-lg)" class="m_e597c321 mantine-CodeHighlight-codeHighlight" dir="ltr"><div class="m_be7e9c9c mantine-CodeHighlight-controls"><button style="--ai-bg:transparent;--ai-hover:transparent;--ai-color:inherit;--ai-bd:none" class="mantine-focus-auto mantine-active m_d498bab7 mantine-CodeHighlight-control m_8d3f4000 mantine-ActionIcon-root m_87cf2631 mantine-UnstyledButton-root" data-variant="none" type="button" aria-label="Copy code"><span class="m_8d3afb97 mantine-ActionIcon-icon"><svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24" stroke-width="2" stroke="currentColor" fill="none" stroke-linecap="round" stroke-linejoin="round"><path stroke="none" d="M0 0h24v24H0z" fill="none"></path><path d="M8 8m0 2a2 2 0 0 1 2 -2h8a2 2 0 0 1 2 2v8a2 2 0 0 1 -2 2h-8a2 2 0 0 1 -2 -2z"></path><path d="M16 8v-2a2 2 0 0 0 -2 -2h-8a2 2 0 0 0 -2 2v8a2 2 0 0 0 2 2h2"></path></svg></span></button></div><div style="--scrollarea-scrollbar-size:calc(0.25rem * var(--mantine-scale));--sa-corner-width:0px;--sa-corner-height:0px" class="m_f744fd40 mantine-CodeHighlight-scrollarea m_d57069b5 mantine-ScrollArea-root" dir="ltr"><div style="overflow-x:hidden;overflow-y:hidden;overscroll-behavior-inline:none" class="m_c0783ff9 mantine-ScrollArea-viewport" data-scrollbars="xy"><div class="m_b1336c6 mantine-ScrollArea-content"><pre class="m_2c47c4fd mantine-CodeHighlight-pre" style="padding:0"><code class="m_5caae6d3 mantine-CodeHighlight-code"><iframe
src="https://www.google.com/maps/embed?pb=..."
loading="lazy"
></iframe></code></pre></div></div></div><button class="mantine-focus-auto m_c9378bc2 mantine-CodeHighlight-showCodeButton m_87cf2631 mantine-UnstyledButton-root" data-hidden="true" type="button">Expand code</button></div>
<p>Встраивание карт Google Maps через iFrame идеально подходит для сайтов, которым нужно показать посетителям локацию, маршруты или контактные данные компании. Такой вариант не требует настройки API и работает стабильно на всех устройствах. Он отлично подходит для страниц с адресами, профилей организаций, лендингов услуг, навигационных указателей.</p>
<h3 id="heading-3-20">Сторонние формы и сервисы</h3>
<p>Через iFrame можно встроить практически любые инструменты, требующие сохранения оригинального дизайна и поведения:</p>
<ul>
<li>платежные виджеты;</li>
<li>квизы, интерактивные анкеты;</li>
<li>калькуляторы стоимости;</li>
<li>формы записи или заявок;</li>
<li>онлайн-чат или службу поддержки.</li>
</ul>
<p>Такой подход особенно удобен, когда сервисы предоставляют готовый embed-код. Это позволяет подключить функционал за минуты, без полноценной интеграции с API и сложной логики. Кроме того, iFrame изолирует внешний сервис от сайта, что повышает стабильность, предотвращает конфликты стилей, скриптов.</p>
<h2 id="heading-2-21">Альтернативы и современные подходы</h2>
<p><img style="--image-object-fit:contain;width:auto" class="m_9e117634 mantine-Image-root" src="https://cdn6.hexlet.io/5FZTKEFicwy3.png" alt="" loading="lazy"/></p>
<p>Несмотря на то что iFrame остаётся простым, универсальным и надежным инструментом, веб-разработка активно движется вперед, предлагая более гибкие и высокопроизводительные решения. Эти подходы позволяют избежать ограничений фреймов, ускорить загрузку страниц и повысить уровень безопасности при интеграции внешнего функционала.</p>
<h3 id="heading-3-22">API-интеграции</h3>
<p>API используют в тех случаях, когда требуется внедрить не готовый интерфейс, а только данные или логику. Такой метод позволяет максимально органично встроить функционал в структуру сайта, сохранив единый дизайн, поведение и UX.</p>
<p>Преимущества API-интеграции:</p>
<ul>
<li>динамический контент подгружается через JavaScript, что делает обновления незаметными, быстрыми;</li>
<li>сайт сохраняет собственную визуальную стилистику, контроль над разметкой;</li>
<li>это наиболее SEO-дружественный вариант, так как весь контент попадает в индекс поисковых систем;</li>
<li>архитектура остаётся гибкой, безопасной, легко масштабируемой.</li>
</ul>
<p>API — лучший выбор для сложных сервисов, систем с постоянными обновлениями, интерфейсов с высокой вариативностью и крупных проектов.</p>
<h3 id="heading-3-23">Web Components (Shadow DOM)</h3>
<p>Технология Web Components позволяет создавать собственные элементы HTML, полностью изолированные от остальной разметки. Используя Shadow DOM, разработчики могут защищать стили и структуру компонента от влияния внешнего CSS и JavaScript.</p>
<p>Преимущества:</p>
<ul>
<li>полная защита от конфликтов CSS, глобальных стилей;</li>
<li>модульность интерфейса, что упрощает поддержку, повторное использование компонентов;</li>
<li>высокая скорость работы за счёт нативной поддержки браузерами;</li>
<li>возможность создавать масштабируемые systems design-библиотеки.</li>
</ul>
<p>Фактически Web Components становятся «iFrame нового поколения», сохраняя изоляцию, но предлагая гораздо более плавную интеграцию, контроль.</p>
<h3 id="heading-3-24">Скриптовые виджеты</h3>
<p>Многие сервисы создают embed-коды на основе обычного:</p>
<div style="margin-bottom:var(--mantine-spacing-lg)" class="m_e597c321 mantine-CodeHighlight-codeHighlight" dir="ltr"><div class="m_be7e9c9c mantine-CodeHighlight-controls"><button style="--ai-bg:transparent;--ai-hover:transparent;--ai-color:inherit;--ai-bd:none" class="mantine-focus-auto mantine-active m_d498bab7 mantine-CodeHighlight-control m_8d3f4000 mantine-ActionIcon-root m_87cf2631 mantine-UnstyledButton-root" data-variant="none" type="button" aria-label="Copy code"><span class="m_8d3afb97 mantine-ActionIcon-icon"><svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24" stroke-width="2" stroke="currentColor" fill="none" stroke-linecap="round" stroke-linejoin="round"><path stroke="none" d="M0 0h24v24H0z" fill="none"></path><path d="M8 8m0 2a2 2 0 0 1 2 -2h8a2 2 0 0 1 2 2v8a2 2 0 0 1 -2 2h-8a2 2 0 0 1 -2 -2z"></path><path d="M16 8v-2a2 2 0 0 0 -2 -2h-8a2 2 0 0 0 -2 2v8a2 2 0 0 0 2 2h2"></path></svg></span></button></div><div style="--scrollarea-scrollbar-size:calc(0.25rem * var(--mantine-scale));--sa-corner-width:0px;--sa-corner-height:0px" class="m_f744fd40 mantine-CodeHighlight-scrollarea m_d57069b5 mantine-ScrollArea-root" dir="ltr"><div style="overflow-x:hidden;overflow-y:hidden;overscroll-behavior-inline:none" class="m_c0783ff9 mantine-ScrollArea-viewport" data-scrollbars="xy"><div class="m_b1336c6 mantine-ScrollArea-content"><pre class="m_2c47c4fd mantine-CodeHighlight-pre" style="padding:0"><code class="m_5caae6d3 mantine-CodeHighlight-code"><script src="..."></script></code></pre></div></div></div><button class="mantine-focus-auto m_c9378bc2 mantine-CodeHighlight-showCodeButton m_87cf2631 mantine-UnstyledButton-root" data-hidden="true" type="button">Expand code</button></div>
<p>При подключении такого скрипта мини-приложение рендерится прямо внутри страницы, но без использования iFrame. Это экономит ресурсы и позволяет детальнее контролировать внешний вид, поведение виджета.</p>
<p>Преимущества скриптовых виджетов:</p>
<ul>
<li>высокая производительность;</li>
<li>отсутствие лишней изоляции;</li>
<li>гибкость интеграции;</li>
<li>легкость обновления функционала поставщиком.</li>
</ul>
<h2 id="heading-2-25">Тренды и развитие</h2>
<p>Современные технологии активно меняют подход к использованию iFrame. Хотя фреймы продолжают оставаться полезным инструментом, их роль постепенно сдвигается в сторону более специализированных и ограниченных сценариев.</p>
<h3 id="heading-3-26">iFrame в SPA</h3>
<p>В одностраничных приложениях (SPA) iFrame применяется точечно, в основном как:</p>
<ul>
<li>внешняя часть микросервиса,</li>
<li>безопасная среда для платёжных форм,</li>
<li>временная зона для подключения нестандартных интеграций.</li>
</ul>
<p>За счёт изоляции он помогает соблюдать требования безопасности и защищать ключевые части приложения.</p>
<h3 id="heading-3-27">Ограничение сторонних ресурсов</h3>
<p>Рост внимания к приватности, безопасности данных повлиял на работу iFrame:</p>
<ul>
<li>cookies внутри iFrame всё чаще становятся недоступными из-за строгих правил браузеров;</li>
<li>для некоторых сценариев требуется явное согласие пользователя;</li>
<li>многие сторонние ресурсы блокируются, если не соответствуют политикам безопасности.</li>
</ul>
<p>Это усложняет внедрение старых решений, но делает веб-среду безопаснее, предсказуемее.</p>
<h3 id="heading-3-28">Рост микрофронтендов</h3>
<p>Современные компании все чаще переходят на архитектуру микрофронтендов. Интерфейс собирается из независимых модулей, каждый из которых может быть создан и обновлён отдельной командой. В некоторых случаях такие модули изолируются внутри iFrame, чтобы:</p>
<ul>
<li>избежать конфликтов стилей,</li>
<li>обеспечить устойчивую работу,</li>
<li>разделить ответственность между командами.</li>
</ul>
<p>Такой подход помогает масштабировать большие проекты, упрощает управление сложными интерфейсами.</p>
<h2 id="heading-2-29">Заключение</h2>
<p>iFrame — это простая и надежная технология, которая остается актуальной несмотря на быстрый рост современных веб-решений. Он позволяет быстро внедрять внешний функционал, обеспечивать изоляцию, интегрировать сложные сервисы без переписывания кода. Однако использование iFrame требует понимания его ограничений — прежде всего в вопросах безопасности и SEO.</p>
<p>Сегодня iFrame часто применяется в связке с API, web-компонентами и SPA-архитектурой, дополняя новые подходы, обеспечивая удобную интеграцию сторонних интерфейсов.</p></div><div class="m_3eebeb36 mantine-Divider-root" data-orientation="horizontal" role="separator"></div><div style="--group-gap:var(--mantine-spacing-md);--group-align:center;--group-justify:flex-start;--group-wrap:wrap;font-size:var(--mantine-font-size-sm)" class="m_4081bf90 mantine-Group-root"><div style="--group-gap:var(--mantine-spacing-xs);--group-align:center;--group-justify:flex-start;--group-wrap:wrap;margin-inline-start:auto" class="m_4081bf90 mantine-Group-root"><svg xmlns="http://www.w3.org/2000/svg" width="16" height="16" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="1.2" stroke-linecap="round" stroke-linejoin="round" class="tabler-icon tabler-icon-calendar "><path d="M4 7a2 2 0 0 1 2 -2h12a2 2 0 0 1 2 2v12a2 2 0 0 1 -2 2h-12a2 2 0 0 1 -2 -2v-12"></path><path d="M16 3v4"></path><path d="M8 3v4"></path><path d="M4 11h16"></path><path d="M11 15h1"></path><path d="M12 15v3"></path></svg><p class="mantine-focus-auto m_b6d8b162 mantine-Text-root" data-inherit="true">2 месяца назад</p></div><div style="--group-gap:var(--mantine-spacing-xs);--group-align:center;--group-justify:flex-start;--group-wrap:wrap" class="m_4081bf90 mantine-Group-root"><svg xmlns="http://www.w3.org/2000/svg" width="16" height="16" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="1.2" stroke-linecap="round" stroke-linejoin="round" class="tabler-icon tabler-icon-user "><path d="M8 7a4 4 0 1 0 8 0a4 4 0 0 0 -8 0"></path><path d="M6 21v-2a4 4 0 0 1 4 -4h4a4 4 0 0 1 4 4v2"></path></svg><p class="mantine-focus-auto m_b6d8b162 mantine-Text-root" data-inherit="true">Nikolai Gagarinov</p></div></div></div></div></div><div style="margin-bottom:var(--mantine-spacing-xl);padding:var(--mantine-spacing-lg)" class="m_e615b15f mantine-Card-root m_1b7284a3 mantine-Paper-root" data-with-border="true" id="answer-3237"><div style="--group-gap:calc(1.125rem * var(--mantine-scale));--group-align:stretch;--group-justify:flex-start;--group-wrap:nowrap" class="m_4081bf90 mantine-Group-root"><div style="--stack-gap:var(--mantine-spacing-md);--stack-align:stretch;--stack-justify:flex-start;font-size:var(--mantine-font-size-h1);font-weight:lighter;text-align:center" class="m_6d731127 mantine-Stack-root">0<a style="color:inherit" class="mantine-focus-auto m_849cf0da m_b6d8b162 mantine-Text-root mantine-Anchor-root" data-underline="hover" href="/qna/glossary/questions/chto-takoe-iframe/answers/3237/vote"><div style="--ti-bg:transparent;--ti-color:var(--mantine-color-indigo-light-color);--ti-bd:calc(0.0625rem * var(--mantine-scale)) solid transparent;color:inherit" class="m_7341320d mantine-ThemeIcon-root" data-variant="transparent"><svg xmlns="http://www.w3.org/2000/svg" width="24" height="24" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2" stroke-linecap="round" stroke-linejoin="round" class="tabler-icon tabler-icon-thumb-up "><path d="M7 11v8a1 1 0 0 1 -1 1h-2a1 1 0 0 1 -1 -1v-7a1 1 0 0 1 1 -1h3a4 4 0 0 0 4 -4v-1a2 2 0 0 1 4 0v5h3a2 2 0 0 1 2 2l-1 5a2 3 0 0 1 -2 2h-7a3 3 0 0 1 -3 -3"></path></svg></div></a></div><div style="--stack-gap:var(--mantine-spacing-md);--stack-align:stretch;--stack-justify:flex-start;width:100%;min-width:0rem" class="m_6d731127 mantine-Stack-root"><div style="margin-bottom:auto" class="m_d08caa0 mantine-Typography-root"><p>iFrame - это элемент HTML, который позволяет встраивать содержимое одного документа в другой. Он создается с помощью тега <!-- --> и содержит содержимое, указанное в атрибуте src. iFrame может использоваться для отображения содержимого других веб-страниц или документов внутри текущего документа, что позволяет создавать сложные веб-страницы с интегрированным содержимым из разных источников.</p></div><div class="m_3eebeb36 mantine-Divider-root" data-orientation="horizontal" role="separator"></div><div style="--group-gap:var(--mantine-spacing-md);--group-align:center;--group-justify:flex-start;--group-wrap:wrap;font-size:var(--mantine-font-size-sm)" class="m_4081bf90 mantine-Group-root"><div style="--group-gap:var(--mantine-spacing-xs);--group-align:center;--group-justify:flex-start;--group-wrap:wrap;margin-inline-start:auto" class="m_4081bf90 mantine-Group-root"><svg xmlns="http://www.w3.org/2000/svg" width="16" height="16" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="1.2" stroke-linecap="round" stroke-linejoin="round" class="tabler-icon tabler-icon-calendar "><path d="M4 7a2 2 0 0 1 2 -2h12a2 2 0 0 1 2 2v12a2 2 0 0 1 -2 2h-12a2 2 0 0 1 -2 -2v-12"></path><path d="M16 3v4"></path><path d="M8 3v4"></path><path d="M4 11h16"></path><path d="M11 15h1"></path><path d="M12 15v3"></path></svg><p class="mantine-focus-auto m_b6d8b162 mantine-Text-root" data-inherit="true">2 года назад</p></div><div style="--group-gap:var(--mantine-spacing-xs);--group-align:center;--group-justify:flex-start;--group-wrap:wrap" class="m_4081bf90 mantine-Group-root"><svg xmlns="http://www.w3.org/2000/svg" width="16" height="16" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="1.2" stroke-linecap="round" stroke-linejoin="round" class="tabler-icon tabler-icon-user "><path d="M8 7a4 4 0 1 0 8 0a4 4 0 0 0 -8 0"></path><path d="M6 21v-2a4 4 0 0 1 4 -4h4a4 4 0 0 1 4 4v2"></path></svg><p class="mantine-focus-auto m_b6d8b162 mantine-Text-root" data-inherit="true">Елена Редькина</p></div></div></div></div></div><style data-mantine-styles="inline">.__m__-_R_4bbdiub_{--carousel-slide-gap:var(--mantine-spacing-xs);--carousel-slide-size:70%;}@media(min-width: 36em){.__m__-_R_4bbdiub_{--carousel-slide-gap:var(--mantine-spacing-xl);--carousel-slide-size:50%;}}</style><div style="--carousel-control-size:calc(2.5rem * var(--mantine-scale));--carousel-controls-offset:var(--mantine-spacing-sm);margin-top:var(--mantine-spacing-xl);margin-bottom:var(--mantine-spacing-lg);padding-block:var(--mantine-spacing-sm);background:var(--app-color-surface)" class="m_17884d0f mantine-Carousel-root responsiveClassName" data-orientation="horizontal" data-include-gap-in-size="true"><div class="m_39bc3463 mantine-Carousel-controls" data-orientation="horizontal"><button class="mantine-focus-auto m_64f58e10 mantine-Carousel-control m_87cf2631 mantine-UnstyledButton-root" type="button" data-inactive="true" data-type="previous" tabindex="-1"><svg viewBox="0 0 15 15" fill="none" xmlns="http://www.w3.org/2000/svg" style="transform:rotate(90deg);width:calc(1rem * var(--mantine-scale));height:calc(1rem * var(--mantine-scale));display:block"><path d="M3.13523 6.15803C3.3241 5.95657 3.64052 5.94637 3.84197 6.13523L7.5 9.56464L11.158 6.13523C11.3595 5.94637 11.6759 5.95657 11.8648 6.15803C12.0536 6.35949 12.0434 6.67591 11.842 6.86477L7.84197 10.6148C7.64964 10.7951 7.35036 10.7951 7.15803 10.6148L3.15803 6.86477C2.95657 6.67591 2.94637 6.35949 3.13523 6.15803Z" fill="currentColor" fill-rule="evenodd" clip-rule="evenodd"></path></svg></button><button class="mantine-focus-auto m_64f58e10 mantine-Carousel-control m_87cf2631 mantine-UnstyledButton-root" type="button" data-inactive="true" data-type="next" tabindex="-1"><svg viewBox="0 0 15 15" fill="none" xmlns="http://www.w3.org/2000/svg" style="transform:rotate(-90deg);width:calc(1rem * var(--mantine-scale));height:calc(1rem * var(--mantine-scale));display:block"><path d="M3.13523 6.15803C3.3241 5.95657 3.64052 5.94637 3.84197 6.13523L7.5 9.56464L11.158 6.13523C11.3595 5.94637 11.6759 5.95657 11.8648 6.15803C12.0536 6.35949 12.0434 6.67591 11.842 6.86477L7.84197 10.6148C7.64964 10.7951 7.35036 10.7951 7.15803 10.6148L3.15803 6.86477C2.95657 6.67591 2.94637 6.35949 3.13523 6.15803Z" fill="currentColor" fill-rule="evenodd" clip-rule="evenodd"></path></svg></button></div><div class="m_a2dae653 mantine-Carousel-viewport" data-type="media"><div class="m_fcd81474 mantine-Carousel-container __m__-_R_4bbdiub_" data-orientation="horizontal"><div class="m_d98df724 mantine-Carousel-slide" data-orientation="horizontal"><div tabindex="0" style="cursor:pointer;height:100%"><a style="text-decoration:none" class="mantine-focus-auto m_849cf0da m_b6d8b162 mantine-Text-root mantine-Anchor-root" data-underline="hover" href="/programs/frontend?promo_name=programs_list&promo_position=qna_question&promo_creative=catalog_card&promo_type=card" target="_blank"><div style="height:100%" class="m_e615b15f mantine-Card-root m_1b7284a3 mantine-Paper-root" data-with-border="true"><div style="--group-gap:calc(0.25rem * var(--mantine-scale));--group-align:center;--group-justify:flex-start;--group-wrap:nowrap" class="m_4081bf90 mantine-Group-root"><span style="font-size:var(--mantine-font-size-sm)" class="mantine-focus-auto m_b6d8b162 mantine-Text-root">10 месяцев</span><span class="mantine-focus-auto m_b6d8b162 mantine-Text-root">·</span><span style="font-size:var(--mantine-font-size-sm)" class="mantine-focus-auto m_b6d8b162 mantine-Text-root">С нуля</span></div><p style="margin-bottom:var(--mantine-spacing-sm);font-size:var(--mantine-font-size-h5);font-weight:bold" class="mantine-focus-auto m_b6d8b162 mantine-Text-root">Фронтенд-разработчик</p><p class="mantine-focus-auto m_b6d8b162 mantine-Text-root">Изучите HTML, CSS, JavaScript и React</p><div style="margin-top:auto" class=""><div class="m_4451eb3a mantine-Center-root"><img style="opacity:0.8;width:70%" class="m_9e117634 mantine-Image-root mantine-visible-from-xs" src="https://hexlet.io/rails/active_storage/representations/proxy/eyJfcmFpbHMiOnsiZGF0YSI6MzcyNywicHVyIjoiYmxvYl9pZCJ9fQ==--2d5cbbf5c3b4a73ae4b2c50632305d78f5872e4d/eyJfcmFpbHMiOnsiZGF0YSI6eyJmb3JtYXQiOiJ3ZWJwIiwicmVzaXplX3RvX2xpbWl0IjpbNDAwLDQwMF0sInNhdmVyIjp7InF1YWxpdHkiOjg1fX0sInB1ciI6InZhcmlhdGlvbiJ9fQ==--5b6f46dacd1af664f27558553a58076185091823/Programmer-rafiki.png" alt="Фронтенд-разработчик" loading="eager"/></div><div style="--group-gap:var(--mantine-spacing-md);--group-align:end;--group-justify:space-between;--group-wrap:wrap;margin-top:var(--mantine-spacing-xs)" class="m_4081bf90 mantine-Group-root"><p style="font-size:var(--mantine-font-size-xl)" class="mantine-focus-auto m_b6d8b162 mantine-Text-root">от 6 792 ₽</p><p style="font-size:var(--mantine-font-size-sm)" class="mantine-focus-auto m_b6d8b162 mantine-Text-root">Посмотреть →</p></div></div></div></a></div></div><div class="m_d98df724 mantine-Carousel-slide" data-orientation="horizontal"><div tabindex="0" style="cursor:pointer;height:100%"><a style="text-decoration:none" class="mantine-focus-auto m_849cf0da m_b6d8b162 mantine-Text-root mantine-Anchor-root" data-underline="hover" href="/programs/professional-layout?promo_name=programs_list&promo_position=qna_question&promo_creative=catalog_card&promo_type=card" target="_blank"><div style="height:100%" class="m_e615b15f mantine-Card-root m_1b7284a3 mantine-Paper-root" data-with-border="true"><div style="--group-gap:calc(0.25rem * var(--mantine-scale));--group-align:center;--group-justify:flex-start;--group-wrap:nowrap" class="m_4081bf90 mantine-Group-root"><span style="font-size:var(--mantine-font-size-sm)" class="mantine-focus-auto m_b6d8b162 mantine-Text-root">5 месяцев</span><span class="mantine-focus-auto m_b6d8b162 mantine-Text-root">·</span><span style="font-size:var(--mantine-font-size-sm)" class="mantine-focus-auto m_b6d8b162 mantine-Text-root">С нуля</span></div><p style="margin-bottom:var(--mantine-spacing-sm);font-size:var(--mantine-font-size-h5);font-weight:bold" class="mantine-focus-auto m_b6d8b162 mantine-Text-root">Профессиональная верстка</p><p class="mantine-focus-auto m_b6d8b162 mantine-Text-root">Адаптивная вёрстка для отображения на любых устройствах </p><div style="margin-top:auto" class=""><div class="m_4451eb3a mantine-Center-root"><img style="opacity:0.8;width:70%" class="m_9e117634 mantine-Image-root mantine-visible-from-xs" src="https://hexlet.io/rails/active_storage/representations/proxy/eyJfcmFpbHMiOnsiZGF0YSI6NDAzNCwicHVyIjoiYmxvYl9pZCJ9fQ==--ba516ea9573bdfcd1d21e2aa0fff8818561828f2/eyJfcmFpbHMiOnsiZGF0YSI6eyJmb3JtYXQiOiJ3ZWJwIiwicmVzaXplX3RvX2xpbWl0IjpbNDAwLDQwMF0sInNhdmVyIjp7InF1YWxpdHkiOjg1fX0sInB1ciI6InZhcmlhdGlvbiJ9fQ==--5b6f46dacd1af664f27558553a58076185091823/Typing-bro.png" alt="Профессиональная верстка" loading="eager"/></div><div style="--group-gap:var(--mantine-spacing-md);--group-align:end;--group-justify:space-between;--group-wrap:wrap;margin-top:var(--mantine-spacing-xs)" class="m_4081bf90 mantine-Group-root"><p style="font-size:var(--mantine-font-size-xl)" class="mantine-focus-auto m_b6d8b162 mantine-Text-root">от 3 900 ₽</p><p style="font-size:var(--mantine-font-size-sm)" class="mantine-focus-auto m_b6d8b162 mantine-Text-root">Посмотреть →</p></div></div></div></a></div></div><div class="m_d98df724 mantine-Carousel-slide" data-orientation="horizontal"><div tabindex="0" style="cursor:pointer;height:100%"><a style="text-decoration:none" class="mantine-focus-auto m_849cf0da m_b6d8b162 mantine-Text-root mantine-Anchor-root" data-underline="hover" href="/programs/layout-designer-positioning?promo_name=programs_list&promo_position=qna_question&promo_creative=catalog_card&promo_type=card" target="_blank"><div style="height:100%" class="m_e615b15f mantine-Card-root m_1b7284a3 mantine-Paper-root" data-with-border="true"><div style="--group-gap:calc(0.25rem * var(--mantine-scale));--group-align:center;--group-justify:flex-start;--group-wrap:nowrap" class="m_4081bf90 mantine-Group-root"><span style="font-size:var(--mantine-font-size-sm)" class="mantine-focus-auto m_b6d8b162 mantine-Text-root">1 месяц</span><span class="mantine-focus-auto m_b6d8b162 mantine-Text-root">·</span><span style="font-size:var(--mantine-font-size-sm)" class="mantine-focus-auto m_b6d8b162 mantine-Text-root">Для продвинутых</span></div><p style="margin-bottom:var(--mantine-spacing-sm);font-size:var(--mantine-font-size-h5);font-weight:bold" class="mantine-focus-auto m_b6d8b162 mantine-Text-root">Позиционирование в CSS</p><p class="mantine-focus-auto m_b6d8b162 mantine-Text-root">Получите навык работы с CSS и адаптивными интерфейсами</p><div style="margin-top:auto" class=""><div class="m_4451eb3a mantine-Center-root"><img style="opacity:0.8;width:70%" class="m_9e117634 mantine-Image-root mantine-visible-from-xs" src="https://hexlet.io/rails/active_storage/representations/proxy/eyJfcmFpbHMiOnsiZGF0YSI6NDAwNCwicHVyIjoiYmxvYl9pZCJ9fQ==--43a2eb3595eeebb3357d478cbcb752d0026363de/eyJfcmFpbHMiOnsiZGF0YSI6eyJmb3JtYXQiOiJ3ZWJwIiwicmVzaXplX3RvX2xpbWl0IjpbNDAwLDQwMF0sInNhdmVyIjp7InF1YWxpdHkiOjg1fX0sInB1ciI6InZhcmlhdGlvbiJ9fQ==--5b6f46dacd1af664f27558553a58076185091823/Website%20Creator-cuate.png" alt="Позиционирование в CSS" loading="eager"/></div><div style="--group-gap:var(--mantine-spacing-md);--group-align:end;--group-justify:space-between;--group-wrap:wrap;margin-top:var(--mantine-spacing-xs)" class="m_4081bf90 mantine-Group-root"><p style="font-size:var(--mantine-font-size-xl)" class="mantine-focus-auto m_b6d8b162 mantine-Text-root">от 3 900 ₽</p><p style="font-size:var(--mantine-font-size-sm)" class="mantine-focus-auto m_b6d8b162 mantine-Text-root">Посмотреть →</p></div></div></div></a></div></div><div class="m_d98df724 mantine-Carousel-slide" data-orientation="horizontal"><div tabindex="0" style="cursor:pointer;height:100%"><a style="text-decoration:none" class="mantine-focus-auto m_849cf0da m_b6d8b162 mantine-Text-root mantine-Anchor-root" data-underline="hover" href="/programs/web-development-free?promo_name=programs_list&promo_position=qna_question&promo_creative=catalog_card&promo_type=card" target="_blank"><div style="height:100%" class="m_e615b15f mantine-Card-root m_1b7284a3 mantine-Paper-root" data-with-border="true"><div style="--group-gap:calc(0.25rem * var(--mantine-scale));--group-align:center;--group-justify:flex-start;--group-wrap:nowrap" class="m_4081bf90 mantine-Group-root"><span style="font-size:var(--mantine-font-size-sm)" class="mantine-focus-auto m_b6d8b162 mantine-Text-root">1 месяц</span><span class="mantine-focus-auto m_b6d8b162 mantine-Text-root">·</span><span style="font-size:var(--mantine-font-size-sm)" class="mantine-focus-auto m_b6d8b162 mantine-Text-root">С нуля</span></div><p style="margin-bottom:var(--mantine-spacing-sm);font-size:var(--mantine-font-size-h5);font-weight:bold" class="mantine-focus-auto m_b6d8b162 mantine-Text-root">Основы веб-разработки</p><p class="mantine-focus-auto m_b6d8b162 mantine-Text-root"></p><div style="margin-top:auto" class=""><div class="m_4451eb3a mantine-Center-root"><img style="opacity:0.8;width:70%" class="m_9e117634 mantine-Image-root mantine-visible-from-xs" src="https://hexlet.io/rails/active_storage/representations/proxy/eyJfcmFpbHMiOnsiZGF0YSI6MzY4NywicHVyIjoiYmxvYl9pZCJ9fQ==--8b6c104f41f902085a7d6e50ea73457f84a3ac33/eyJfcmFpbHMiOnsiZGF0YSI6eyJmb3JtYXQiOiJ3ZWJwIiwicmVzaXplX3RvX2xpbWl0IjpbNDAwLDQwMF0sInNhdmVyIjp7InF1YWxpdHkiOjg1fX0sInB1ciI6InZhcmlhdGlvbiJ9fQ==--5b6f46dacd1af664f27558553a58076185091823/Coding-amico.png" alt="Основы веб-разработки" loading="eager"/></div><div style="--group-gap:var(--mantine-spacing-md);--group-align:end;--group-justify:space-between;--group-wrap:wrap;margin-top:var(--mantine-spacing-xs)" class="m_4081bf90 mantine-Group-root"><p style="font-size:var(--mantine-font-size-xl)" class="mantine-focus-auto m_b6d8b162 mantine-Text-root">Бесплатно</p><p style="font-size:var(--mantine-font-size-sm)" class="mantine-focus-auto m_b6d8b162 mantine-Text-root">Посмотреть →</p></div></div></div></a></div></div><div class="m_d98df724 mantine-Carousel-slide" data-orientation="horizontal"><div tabindex="0" style="cursor:pointer;height:100%"><a style="text-decoration:none" class="mantine-focus-auto m_849cf0da m_b6d8b162 mantine-Text-root mantine-Anchor-root" data-underline="hover" href="/programs/javascript-basics-free?promo_name=programs_list&promo_position=qna_question&promo_creative=catalog_card&promo_type=card" target="_blank"><div style="height:100%" class="m_e615b15f mantine-Card-root m_1b7284a3 mantine-Paper-root" data-with-border="true"><div style="--group-gap:calc(0.25rem * var(--mantine-scale));--group-align:center;--group-justify:flex-start;--group-wrap:nowrap" class="m_4081bf90 mantine-Group-root"><span style="font-size:var(--mantine-font-size-sm)" class="mantine-focus-auto m_b6d8b162 mantine-Text-root">1 месяц</span><span class="mantine-focus-auto m_b6d8b162 mantine-Text-root">·</span><span style="font-size:var(--mantine-font-size-sm)" class="mantine-focus-auto m_b6d8b162 mantine-Text-root">С нуля</span></div><p style="margin-bottom:var(--mantine-spacing-sm);font-size:var(--mantine-font-size-h5);font-weight:bold" class="mantine-focus-auto m_b6d8b162 mantine-Text-root">Основы JavaScript</p><p class="mantine-focus-auto m_b6d8b162 mantine-Text-root"></p><div style="margin-top:auto" class=""><div class="m_4451eb3a mantine-Center-root"><img style="opacity:0.8;width:70%" class="m_9e117634 mantine-Image-root mantine-visible-from-xs" src="https://hexlet.io/rails/active_storage/representations/proxy/eyJfcmFpbHMiOnsiZGF0YSI6MzY3OSwicHVyIjoiYmxvYl9pZCJ9fQ==--63b1e4a498081a9ffcf9ba460ef4249e57663579/eyJfcmFpbHMiOnsiZGF0YSI6eyJmb3JtYXQiOiJ3ZWJwIiwicmVzaXplX3RvX2xpbWl0IjpbNDAwLDQwMF0sInNhdmVyIjp7InF1YWxpdHkiOjg1fX0sInB1ciI6InZhcmlhdGlvbiJ9fQ==--5b6f46dacd1af664f27558553a58076185091823/Coding%20workshop-pana.png" alt="Основы JavaScript" loading="eager"/></div><div style="--group-gap:var(--mantine-spacing-md);--group-align:end;--group-justify:space-between;--group-wrap:wrap;margin-top:var(--mantine-spacing-xs)" class="m_4081bf90 mantine-Group-root"><p style="font-size:var(--mantine-font-size-xl)" class="mantine-focus-auto m_b6d8b162 mantine-Text-root">Бесплатно</p><p style="font-size:var(--mantine-font-size-sm)" class="mantine-focus-auto m_b6d8b162 mantine-Text-root">Посмотреть →</p></div></div></div></a></div></div><div class="m_d98df724 mantine-Carousel-slide" data-orientation="horizontal"><div tabindex="0" style="cursor:pointer;height:100%"><a style="text-decoration:none" class="mantine-focus-auto m_849cf0da m_b6d8b162 mantine-Text-root mantine-Anchor-root" data-underline="hover" href="/courses?promo_name=programs_list&promo_position=qna_question&promo_creative=catalog_card&promo_type=card"><div style="height:100%" class="m_e615b15f mantine-Card-root m_1b7284a3 mantine-Paper-root" data-with-border="true"><h2 style="--title-fw:var(--mantine-h2-font-weight);--title-lh:var(--mantine-h2-line-height);--title-fz:var(--mantine-h2-font-size);margin-bottom:var(--mantine-spacing-md);font-size:var(--mantine-font-size-h3)" class="m_8a5d1357 mantine-Title-root" data-order="2" data-responsive="true">Каталог</h2><p style="margin-bottom:auto" class="mantine-focus-auto m_b6d8b162 mantine-Text-root">Полный список доступных курсов по разным направлениям</p><div style="margin-top:auto" class=""><div class="m_4451eb3a mantine-Center-root"><img style="opacity:0.8;width:70%" class="m_9e117634 mantine-Image-root mantine-visible-from-xs" src="/vite/assets/development-BVihs_d5.png" alt="Orientation"/></div></div></div></a></div></div></div></div></div></div><style data-mantine-styles="inline">.__m__-_R_5diub_{--col-flex-grow:auto;--col-flex-basis:100%;--col-max-width:100%;}@media(min-width: 48em){.__m__-_R_5diub_{--col-flex-grow:auto;--col-flex-basis:16.666666666666668%;--col-max-width:16.666666666666668%;}}@media(min-width: 62em){.__m__-_R_5diub_{--col-flex-grow:auto;--col-flex-basis:33.333333333333336%;--col-max-width:33.333333333333336%;}}</style><div class="m_96bdd299 mantine-Grid-col __m__-_R_5diub_ mantine-visible-from-md"><div style="margin-bottom:var(--mantine-spacing-xl);padding:var(--mantine-spacing-xl);background:var(--mantine-color-blue-0);width:100%" class="m_e615b15f mantine-Card-root m_1b7284a3 mantine-Paper-root"><p style="margin-bottom:var(--mantine-spacing-sm);font-size:var(--mantine-font-size-h4)" class="mantine-focus-auto m_b6d8b162 mantine-Text-root">Похожие вопросы</p><ul class="m_abbac491 mantine-List-root"><li style="margin-bottom:var(--mantine-spacing-xs)" class="m_abb6bec2 mantine-List-item" data-with-icon="true"><div class="m_75cd9f71 mantine-List-itemWrapper"><span class="m_60f83e5b mantine-List-itemIcon"><div class="m_4451eb3a mantine-Center-root"><div style="--ti-size:var(--ti-size-xs);--ti-bg:transparent;--ti-color:var(--mantine-color-indigo-light-color);--ti-bd:calc(0.0625rem * var(--mantine-scale)) solid transparent;color:inherit" class="m_7341320d mantine-ThemeIcon-root" data-variant="transparent" data-size="xs"><svg xmlns="http://www.w3.org/2000/svg" width="24" height="24" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2" stroke-linecap="round" stroke-linejoin="round" class="tabler-icon tabler-icon-chevron-compact-right "><path d="M11 4l3 8l-3 8"></path></svg></div></div></span><span class="mantine-List-itemLabel"><a class="mantine-focus-auto m_849cf0da m_b6d8b162 mantine-Text-root mantine-Anchor-root" data-underline="hover" href="/qna/glossary/questions/chto-takoe-pandas">Pandas</a></span></div></li><li style="margin-bottom:var(--mantine-spacing-xs)" class="m_abb6bec2 mantine-List-item" data-with-icon="true"><div class="m_75cd9f71 mantine-List-itemWrapper"><span class="m_60f83e5b mantine-List-itemIcon"><div class="m_4451eb3a mantine-Center-root"><div style="--ti-size:var(--ti-size-xs);--ti-bg:transparent;--ti-color:var(--mantine-color-indigo-light-color);--ti-bd:calc(0.0625rem * var(--mantine-scale)) solid transparent;color:inherit" class="m_7341320d mantine-ThemeIcon-root" data-variant="transparent" data-size="xs"><svg xmlns="http://www.w3.org/2000/svg" width="24" height="24" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2" stroke-linecap="round" stroke-linejoin="round" class="tabler-icon tabler-icon-chevron-compact-right "><path d="M11 4l3 8l-3 8"></path></svg></div></div></span><span class="mantine-List-itemLabel"><a class="mantine-focus-auto m_849cf0da m_b6d8b162 mantine-Text-root mantine-Anchor-root" data-underline="hover" href="/qna/glossary/questions/chto-takoe-1c-buhgalteriya">1C:Бухгалтерия</a></span></div></li><li style="margin-bottom:var(--mantine-spacing-xs)" class="m_abb6bec2 mantine-List-item" data-with-icon="true"><div class="m_75cd9f71 mantine-List-itemWrapper"><span class="m_60f83e5b mantine-List-itemIcon"><div class="m_4451eb3a mantine-Center-root"><div style="--ti-size:var(--ti-size-xs);--ti-bg:transparent;--ti-color:var(--mantine-color-indigo-light-color);--ti-bd:calc(0.0625rem * var(--mantine-scale)) solid transparent;color:inherit" class="m_7341320d mantine-ThemeIcon-root" data-variant="transparent" data-size="xs"><svg xmlns="http://www.w3.org/2000/svg" width="24" height="24" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2" stroke-linecap="round" stroke-linejoin="round" class="tabler-icon tabler-icon-chevron-compact-right "><path d="M11 4l3 8l-3 8"></path></svg></div></div></span><span class="mantine-List-itemLabel"><a class="mantine-focus-auto m_849cf0da m_b6d8b162 mantine-Text-root mantine-Anchor-root" data-underline="hover" href="/qna/glossary/questions/chto-takoe-1c-predpriyatie">1C:Предприятие</a></span></div></li><li style="margin-bottom:var(--mantine-spacing-xs)" class="m_abb6bec2 mantine-List-item" data-with-icon="true"><div class="m_75cd9f71 mantine-List-itemWrapper"><span class="m_60f83e5b mantine-List-itemIcon"><div class="m_4451eb3a mantine-Center-root"><div style="--ti-size:var(--ti-size-xs);--ti-bg:transparent;--ti-color:var(--mantine-color-indigo-light-color);--ti-bd:calc(0.0625rem * var(--mantine-scale)) solid transparent;color:inherit" class="m_7341320d mantine-ThemeIcon-root" data-variant="transparent" data-size="xs"><svg xmlns="http://www.w3.org/2000/svg" width="24" height="24" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2" stroke-linecap="round" stroke-linejoin="round" class="tabler-icon tabler-icon-chevron-compact-right "><path d="M11 4l3 8l-3 8"></path></svg></div></div></span><span class="mantine-List-itemLabel"><a class="mantine-focus-auto m_849cf0da m_b6d8b162 mantine-Text-root mantine-Anchor-root" data-underline="hover" href="/qna/glossary/questions/chto-takoe-a-b-testirovanie">A/B-тестирование</a></span></div></li><li style="margin-bottom:var(--mantine-spacing-xs)" class="m_abb6bec2 mantine-List-item" data-with-icon="true"><div class="m_75cd9f71 mantine-List-itemWrapper"><span class="m_60f83e5b mantine-List-itemIcon"><div class="m_4451eb3a mantine-Center-root"><div style="--ti-size:var(--ti-size-xs);--ti-bg:transparent;--ti-color:var(--mantine-color-indigo-light-color);--ti-bd:calc(0.0625rem * var(--mantine-scale)) solid transparent;color:inherit" class="m_7341320d mantine-ThemeIcon-root" data-variant="transparent" data-size="xs"><svg xmlns="http://www.w3.org/2000/svg" width="24" height="24" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2" stroke-linecap="round" stroke-linejoin="round" class="tabler-icon tabler-icon-chevron-compact-right "><path d="M11 4l3 8l-3 8"></path></svg></div></div></span><span class="mantine-List-itemLabel"><a class="mantine-focus-auto m_849cf0da m_b6d8b162 mantine-Text-root mantine-Anchor-root" data-underline="hover" href="/qna/glossary/questions/chto-takoe-agile">Agile</a></span></div></li></ul></div><div style="justify-content:end;margin-top:0rem;position:sticky;top:calc(5rem * var(--mantine-scale))" class="m_8bffd616 mantine-Flex-root __m__-_R_1bddiub_"><div tabindex="0" style="cursor:pointer"><a style="text-decoration:none" class="mantine-focus-auto m_849cf0da m_b6d8b162 mantine-Text-root mantine-Anchor-root" data-underline="hover" href="/courses_web_development?promo_name=program_category&promo_position=qna_question&promo_creative=card&promo_type=card"><div style="background-color:var(--mantine-color-default);border:calc(0.0625rem * var(--mantine-scale)) solid var(--mantine-color-default-border);padding-inline:var(--mantine-spacing-xl);padding-top:var(--mantine-spacing-xl);padding-bottom:var(--mantine-spacing-xs);width:100%" class="m_e615b15f mantine-Card-root m_1b7284a3 mantine-Paper-root"><div class="m_4451eb3a mantine-Center-root" data-inline="true"><p style="font-size:var(--mantine-font-size-h4)" class="mantine-focus-auto m_b6d8b162 mantine-Text-root">Курсы по веб-разработке</p></div><img class="m_9e117634 mantine-Image-root" src="/vite/assets/development-BVihs_d5.png"/><p style="margin-bottom:var(--mantine-spacing-xs);text-align:right" class="mantine-focus-auto m_b6d8b162 mantine-Text-root">Посмотреть →</p></div></a></div></div></div></div></div></div></div>
</main>
<footer class="bg-dark fw-light text-light px-3 py-5">
<div class="row small">
<div class="col-12 col-sm-6 col-md-3">
<div class="h5 mb-3">Хекслет</div>
<ul class="list-unstyled">
<li>
<a class="nav-link link-light py-1 ps-0" href="/pages/about">О нас</a>
</li>
<li>
<a class="nav-link link-light py-1 ps-0" href="/testimonials">Отзывы</a>
</li>
<li>
<span class="nav-link link-light py-1 ps-0 external-link" data-href="https://b2b.hexlet.io" role="button">Корпоративное обучение</span>
</li>
<li>
<a class="nav-link link-light py-1 ps-0" href="/blog">Блог</a>
</li>
<li>
<a class="nav-link link-light py-1 ps-0" href="/qna">Вопросы и ответы</a>
</li>
<li>
<a class="nav-link link-light py-1 ps-0" href="/glossary">Глоссарий</a>
</li>
<li>
<span class="nav-link link-light py-1 ps-0 external-link" data-href="https://help.hexlet.io" data-target="_blank" role="button">Справка</span>
</li>
<li>
<a class="nav-link link-light py-1 ps-0" target="_blank" rel="noopener noreferrer" href="/map">Карта сайта</a>
</li>
</ul>
</div>
<div class="col-12 col-sm-6 col-md-3">
<div class="h5 fw-normal mb-3">Направления</div>
<ul class="list-unstyled">
<li>
<a class="nav-link link-light py-1 ps-0" href="/courses_devops">DevOps
</a></li>
<li>
<a class="nav-link link-light py-1 ps-0" href="/courses_data_analytics">Аналитика
</a></li>
<li>
<a class="nav-link link-light py-1 ps-0" href="/courses_backend_development">Бэкенд
</a></li>
<li>
<a class="nav-link link-light py-1 ps-0" href="/courses_programming">Программирование
</a></li>
<li>
<a class="nav-link link-light py-1 ps-0" href="/courses_testing">Тестирование
</a></li>
<li>
<a class="nav-link link-light py-1 ps-0" href="/courses_front_end_dev">Фронтенд
</a></li>
</ul>
</div>
<div class="col-12 col-sm-6 col-md-3">
<div class="h5">Профессии</div>
<ul class="list-unstyled">
<li>
<a class="nav-link link-light py-1 ps-0" href="/programs/devops-engineer-from-scratch">DevOps-инженер с нуля</a>
</li>
<li>
<a class="nav-link link-light py-1 ps-0" href="/programs/go">Go-разработчик</a>
</li>
<li>
<a class="nav-link link-light py-1 ps-0" href="/programs/java">Java-разработчик</a>
</li>
<li>
<a class="nav-link link-light py-1 ps-0" href="/programs/python">Python-разработчик </a>
</li>
<li>
<a class="nav-link link-light py-1 ps-0" href="/programs/data-analytics">Аналитик данных</a>
</li>
<li>
<a class="nav-link link-light py-1 ps-0" href="/programs/qa-engineer">Инженер по ручному тестированию</a>
</li>
<li>
<a class="nav-link link-light py-1 ps-0" href="/programs/php">РНР-разработчик</a>
</li>
<li>
<a class="nav-link link-light py-1 ps-0" href="/programs/frontend">Фронтенд-разработчик</a>
</li>
</ul>
</div>
<div class="col-12 col-sm-6 col-md-3">
<div class="h5">Навыки</div>
<ul class="list-unstyled">
<li>
<a class="nav-link link-light py-1 ps-0" href="/programs/python-django-developer">Django</a>
</li>
<li>
<a class="nav-link link-light py-1 ps-0" href="/programs/docker">Docker</a>
</li>
<li>
<a class="nav-link link-light py-1 ps-0" href="/programs/php-laravel-developer">Laravel</a>
</li>
<li>
<a class="nav-link link-light py-1 ps-0" href="/programs/postman">Postman</a>
</li>
<li>
<a class="nav-link link-light py-1 ps-0" href="/programs/js-react-developer">React</a>
</li>
<li>
<a class="nav-link link-light py-1 ps-0" href="/programs/js-rest-api">REST API в Node.js</a>
</li>
<li>
<a class="nav-link link-light py-1 ps-0" href="/programs/spring-boot">Spring Boot</a>
</li>
<li>
<a class="nav-link link-light py-1 ps-0" href="/programs/typescript">Typescript</a>
</li>
</ul>
</div>
</div>
<hr>
<div class="row">
<div class="col-12 col-sm-4 col-md-2">
<div class="fs-4">
<ul class="list-unstyled d-flex">
<li class="me-3">
<a aria-label="Telegram" target="_blank" class="link-light" rel="noopener noreferrer nofollow" href="https://t.me/hexlet_ru"><span class="bi bi-telegram"></span>
</a></li>
<li>
<a aria-label="Youtube" target="_blank" class="link-light" rel="noopener noreferrer nofollow" href="https://www.youtube.com/user/HexletUniversity"><span class="bi bi-youtube"></span>
</a></li>
</ul>
</div>
<div class="mb-2 d-flex flex-column">
<a class="link-light text-decoration-none" rel="nofollow" href="mailto:support@hexlet.io">support@hexlet.io</a>
<a class="link-light text-decoration-none py-2" target="_blank" href="https://t.me/hexlet_help_bot">t.me/hexlet_help_bot</a>
</div>
<ul class="list-unstyled d-flex">
<li class="me-3">
<span class="link-light text-decoration-none opacity-50 x-font-size-18 external-link" rel="nofollow" data-href="https://hexlet.io/locale/switch?new_locale=en" data-target="_self" role="button"><span class="my-auto">EN</span>
</span></li>
<li class="me-3">
<span class="link-light text-decoration-none opacity-50 x-font-size-18 opacity-100 external-link" rel="nofollow" data-href="https://ru.hexlet.io/locale/switch?new_locale=ru" data-target="_self" role="button"><span class="my-auto">RU</span>
</span></li>
<li class="me-3">
<span class="link-light text-decoration-none opacity-50 x-font-size-18 external-link" rel="nofollow" data-href="https://kz.hexlet.io/locale/switch?new_locale=kz" data-target="_self" role="button"><span class="my-auto">KZ</span>
</span></li>
</ul>
</div>
<div class="col-12 col-sm-4 col-md-3">
<ul class="list-unstyled fs-4">
<li class="mb-3">
<a class="link-light text-decoration-none" href="tel:8%20800%20100%2022%2047">8 800 100 22 47</a>
<span class="d-block opacity-50 small">бесплатно по РФ</span>
</li>
<li>
<a class="link-light text-decoration-none" href="tel:%2B7%20495%20085%2021%2062">+7 495 085 21 62</a>
<span class="d-block opacity-50 small">бесплатно по Москве</span>
</li>
</ul>
</div>
<div class="col-12 col-sm-4 col-md-3">
<div class="small mb-3">Образовательные услуги оказываются на основании Л035-01298-77/01989008 от 14.03.2025</div>
<ul class="list-unstyled small">
<li>
<a class="nav-link link-light py-1 ps-0" href="/pages/legal">Правовая информация</a>
</li>
<li>
<a class="nav-link link-light py-1 ps-0" href="/pages/offer">Оферта</a>
</li>
<li>
<a class="nav-link link-light py-1 ps-0" href="/pages/license">Лицензия</a>
</li>
<li>
<a class="nav-link link-light py-1 ps-0" href="/pages/contacts">Контакты</a>
</li>
</ul>
</div>
<div class="col-12 col-sm-12 col-md-4 small">
<div class="mb-2">
<div>ООО «<a href="/" class="text-decoration-none link-light">Хекслет Рус</a>»</div>
<div>108813 г. Москва, вн.тер.г. поселение Московский,</div>
<div>г. Московский, ул. Солнечная, д. 3А, стр. 1, помещ. 20Б/3</div>
<div>ОГРН 1217300010476</div>
<div>ИНН 7325174845</div>
</div>
<hr>
<div>АНО ДПО «<a href="/" class="text-decoration-none link-light">Учебный центр «Хекслет</a>»</div>
<div>119331 г. Москва, вн. тер. г. муниципальный округ</div>
<div>Ломоносовский, пр-кт Вернадского, д. 29</div>
<div>ОГРН 1247700712390</div>
<div>ИНН 7736364948</div>
</div>
</div>
</footer>
<div id="root-assistant-offcanvas"></div>
<script src="/vite/assets/assistant-Bukl1lYy.js" crossorigin="anonymous" type="module"></script><link rel="modulepreload" href="/vite/assets/chunk-DsPFFUou.js" as="script" crossorigin="anonymous">
<link rel="modulepreload" href="/vite/assets/init-BrRXra1y.js" as="script" crossorigin="anonymous">
<link rel="modulepreload" href="/vite/assets/ErrorFallbackBlock-naDSYSy9.js" as="script" crossorigin="anonymous">
<link rel="modulepreload" href="/vite/assets/MarkdownBlock-DbyKWoR_.js" as="script" crossorigin="anonymous">
<link rel="modulepreload" href="/vite/assets/gon-D3e4yh1x.js" as="script" crossorigin="anonymous">
<link rel="modulepreload" href="/vite/assets/mantine-CGMYrt2Y.js" as="script" crossorigin="anonymous">
<link rel="modulepreload" href="/vite/assets/shiki-V011pkdv.js" as="script" crossorigin="anonymous">
<link rel="modulepreload" href="/vite/assets/utils-DRqSHbQE.js" as="script" crossorigin="anonymous">
<link rel="modulepreload" href="/vite/assets/routes-CCH8ilKF.js" as="script" crossorigin="anonymous">
<link rel="modulepreload" href="/vite/assets/lib-XR8Qr8kR.js" as="script" crossorigin="anonymous">
<link rel="modulepreload" href="/vite/assets/dist-GCHh59xr.js" as="script" crossorigin="anonymous">
<link rel="modulepreload" href="/vite/assets/Box-B5-OOzBf.js" as="script" crossorigin="anonymous">
<link rel="modulepreload" href="/vite/assets/notifications.store-C-3AFSMn.js" as="script" crossorigin="anonymous">
<link rel="modulepreload" href="/vite/assets/useIsomorphicEffect-HJ6VK0D3.js" as="script" crossorigin="anonymous">
<link rel="modulepreload" href="/vite/assets/lib-KSp6QbZ0.js" as="script" crossorigin="anonymous">
<link rel="modulepreload" href="/vite/assets/axios-BEvgo0ym.js" as="script" crossorigin="anonymous">
<link rel="modulepreload" href="/vite/assets/classnames-l6ipYlLR.js" as="script" crossorigin="anonymous">
<link rel="modulepreload" href="/vite/assets/dayjs.min-BkKovM-s.js" as="script" crossorigin="anonymous">
<link rel="modulepreload" href="/vite/assets/debounce-jMQ_Cf4f.js" as="script" crossorigin="anonymous">
<link rel="modulepreload" href="/vite/assets/i18next-BlSq9s7B.js" as="script" crossorigin="anonymous">
<link rel="modulepreload" href="/vite/assets/client-U9M77rxp.js" as="script" crossorigin="anonymous">
<link rel="modulepreload" href="/vite/assets/react-dom-DaLxUz_h.js" as="script" crossorigin="anonymous">
<link rel="modulepreload" href="/vite/assets/useTranslation-Bx1Cdrkz.js" as="script" crossorigin="anonymous">
<link rel="modulepreload" href="/vite/assets/compiler-runtime-6XxiPFnt.js" as="script" crossorigin="anonymous">
<link rel="modulepreload" href="/vite/assets/jsx-runtime-CwjcCKJi.js" as="script" crossorigin="anonymous">
<link rel="modulepreload" href="/vite/assets/react-CkL4ZRHB.js" as="script" crossorigin="anonymous">
<script defer src="https://static.cloudflareinsights.com/beacon.min.js/v67327c56f0bb4ef8b305cae61679db8f1769101564043" integrity="sha512-rdcWY47ByXd76cbCFzznIcEaCN71jqkWBBqlwhF1SY7KubdLKZiEGeP7AyieKZlGP9hbY/MhGrwXzJC/HulNyg==" data-cf-beacon='{"version":"2024.11.0","token":"d11015b65d11429ea6b4a2ef37dd7e0b","server_timing":{"name":{"cfCacheStatus":true,"cfEdge":true,"cfExtPri":true,"cfL4":true,"cfOrigin":true,"cfSpeedBrain":true},"location_startswith":null}}' crossorigin="anonymous"></script>
</body>
</html>