Yandex Cloud
Поиск
Связаться с намиПодключиться
  • Документация
  • Блог
  • Все сервисы
  • Статус работы сервисов
    • Популярные
    • Инфраструктура и сеть
    • Платформа данных
    • Контейнеры
    • Инструменты разработчика
    • Бессерверные вычисления
    • Безопасность
    • Мониторинг и управление ресурсами
    • Машинное обучение
    • Бизнес-инструменты
  • Все решения
    • По отраслям
    • По типу задач
    • Экономика платформы
    • Безопасность
    • Техническая поддержка
    • Каталог партнёров
    • Обучение и сертификация
    • Облако для стартапов
    • Облако для крупного бизнеса
    • Центр технологий для общества
    • Облако для интеграторов
    • Поддержка IT-бизнеса
    • Облако для фрилансеров
    • Обучение и сертификация
    • Блог
    • Документация
    • Контент-программа
    • Мероприятия и вебинары
    • Контакты, чаты и сообщества
    • Идеи
    • Истории успеха
    • Тарифы Yandex Cloud
    • Промоакции и free tier
    • Правила тарификации
  • Документация
  • Блог
Проект Яндекса
© 2025 ООО «Яндекс.Облако»
Yandex SmartCaptcha
  • Начало работы
    • Все инструкции
    • Создать капчу
    • Удалить капчу
    • Получить ключи
    • Добавить виджет расширенным методом
    • Проверить капчу
    • Посмотреть операции с ресурсами сервиса
  • Управление доступом
  • Правила тарификации
  • Справочник Terraform
  • Метрики Monitoring
  • Аудитные логи Audit Trails
  • История изменений

В этой статье:

  • Добавьте виджет SmartCaptcha расширенным методом
  • Добавьте виджет SmartCaptcha при необходимости
  • Что дальше
  1. Пошаговые инструкции
  2. Добавить виджет расширенным методом

Добавьте виджет SmartCaptcha

Статья создана
Yandex Cloud
Обновлена 3 июля 2024 г.
  • Добавьте виджет SmartCaptcha расширенным методом
  • Добавьте виджет SmartCaptcha при необходимости
  • Что дальше

Добавьте виджет SmartCaptcha расширенным методомДобавьте виджет SmartCaptcha расширенным методом

Вы управляете загрузкой виджета через объект window.smartCaptcha. В инструкции для этого используется callback-функция onloadFunction:

  1. Подключите JS-скрипт к странице пользователя. Для этого разместите следующий код в любом месте страницы, например, внутри тега <head>:

    <script
        src="https://smartcaptcha.yandexcloud.net/captcha.js?render=onload&onload=onloadFunction"
        defer
    ></script>
    
  2. Добавьте на страницу пустой контейнер, в который будет вставлен виджет:

    <div id="<идентификатор_контейнера>"></div>
    

    Где id — произвольный идентификатор.

  3. Добавьте на страницу код callback-функции:

    <script>
        function onloadFunction() {
        if (window.smartCaptcha) {
            const container = document.getElementById('<идентификатор_контейнера>');
    
            const widgetId = window.smartCaptcha.render(container, {
                sitekey: '<ключ_клиента>',
                hl: '<язык>',
            });
        }
        }
    </script>
    

    Где:

    • <идентификатор_контейнера> — идентификатор, сгенерированный на предыдущем шаге;
    • sitekey — ключ клиентской части;
    • hl — язык виджета и задания.

    В код callback-функции стоит добавить проверку существования объекта window.smartCaptcha, чтобы не вызвать ошибку в случае вызова функции до завершения загрузки JS-скрипта.

    Примечание

    При загрузке виджет меняет высоту контейнера, в котором он находится, на 100px. Это может привести к нежелательному «скачку» верстки на странице из-за изменения высоты. Чтобы избавиться от этого «скачка», вы можете задать до загрузки виджета высоту контейнера 100px.

    <div ... style="height: 100px"></div>
    

Добавьте виджет SmartCaptcha при необходимостиДобавьте виджет SmartCaptcha при необходимости

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

window.onloadFunction = () => {
  if (window.smartCaptcha) {
    // Создание капчи
  }
}

function handleScriptLoadingError() {
  // Обработка ошибок
}

const scriptElement = document.createElement('script');
scriptElement.src = 'https://smartcaptcha.yandexcloud.net/captcha.js?render=onload&onload=onloadFunction';
scriptElement.onerror = handleScriptLoadingError;
document.body.appendChild(scriptElement);

Что дальшеЧто дальше

  • Невидимая капча.
  • Подключение капчи в React.

Была ли статья полезна?

Предыдущая
Получить ключи
Следующая
Проверить капчу
Проект Яндекса
© 2025 ООО «Яндекс.Облако»