На этой странице:

Twin LiveDemo

Данный кейс поддерживается телеграм ботом LiveDemo – ID этого кейса: 139952299. 

Подробнее про LiveDemo

В этой статье мы разберем, каким образом можно отправить сообщение с inline-кнопками в Telegram.

Что такое inline-кнопка

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

Типы inline-кнопок

API Telegram позволяет создавать inline-кнопки двух типов:

  • Кнопка для перехода по ссылке. Ссылка, связанная с кнопкой, будет открыта во внешнем браузере.

  • Кнопка для открытия веб-приложения (WebApp). Ссылка, связанная с кнопкой, будет открыта как веб-приложение внутри встроенного в Telegram окна.

Как отправить сообщение с inline-кнопкой

Для отправки такого сообщения нужно использовать метод отправки сообщения в блоке запроса к серверу. Разберем подробнее:

Фрагмент сценария

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

Параметры блоков

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

  • bot_token – токен бота Telegram, который можно получить при создании бота в BotFather.

    Подробнее о создании бота в Telegram можно узнать в этой статье.

  • chat_id – идентификатор чата, в который будет отправлено сообщение. Существует два возможных значения: для отправки сообщения в текущий чат, используется системная переменная {messengerUserId}. Для отправки сообщения в другой чат, можно ввести идентификатор нужного чата. Получить его можно с помощью IDBot в Telegram.

  • text – текст отправляемого сообщения.



2. Затем поставьте блок запроса к серверу со следующими параметрами:

ПараметрЗначение
Тип запросаPOST
URLhttps://api.telegram.org/bot{bot_token}/sendMessage?chat_id={chat_id}&text={text}
Тип содержимогоjson


В теле запроса передается текст кнопки, и ссылка, которая открывается при нажатии кнопки. Для каждой кнопки требуются два поля в теле запроса:

Для кнопки перехода по ссылке:

Название поляЗначение поля
reply_markup.inline_keyboard.0.0.textТекст кнопки.
reply_markup.inline_keyboard.0.0.urlСсылка, которая откроется при нажатии кнопки.

Для кнопки открытия веб-приложения:

Название поляЗначение поля
reply_markup.inline_keyboard.0.0.textТекст кнопки.
reply_markup.inline_keyboard.0.0.web_app.urlСсылка, которая откроется как веб-приложение внутри Telegram при нажатии кнопки.

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

Название поля
reply_markup.inline_keyboard.0.0.text
reply_markup.inline_keyboard.0.0.url
reply_markup.inline_keyboard.0.1.text
reply_markup.inline_keyboard.0.1.url



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

Название поля
reply_markup.inline_keyboard.0.0.text
reply_markup.inline_keyboard.0.0.url
reply_markup.inline_keyboard.1.0.text
reply_markup.inline_keyboard.1.0.url

Таким образом можно добавлять по несколько кнопок в каждую строку. Например, с 3 кнопками и нумерацией 0.0, 0.1, 1.0 можно получить такой результат:



Так вы можете отправить сообщение с inline-кнопками в Telegram.

Пример работы


Нажмите на кнопку со ссылкой на сайт.


Откроется окошко подтверждения, нажмите ОК, чтобы открыть веб-приложение внутри Telegram.


Откроется веб-приложение.




  • Нет меток