Skip to content

事件 - Events

事件是 Telegram 本地应用程序在 完成某些外部操作时发送的信号。 与方法一样,每个事件都有自己独特的名称和参数。

网页版

如前所述,网页版使用 iframe 之间的标准通信方式。 这意味着 父 iframe 可以通过 window.postMessage 函数发送事件。 要处理这类 消息,只需在全局 window 对象上添加 message 事件监听器即可:

typescript
window.addEventListener('message', ...);

本地应用程序将发送一个带有 data: string 的事件,该字符串代表已转换为字符串的 JSON 对象 。 该对象的接口与我们在 方法 部分中定义的接口相同:

typescript
interface MessageJSON {
  eventType: string;
  eventData: any;
}

然后,让我们想象一下如何处理 Telegram 应用程序中的事件:

typescript
window.addEventListener('message', ({ data }) => {
  const { eventType, eventData } = JSON.parse(data);
  console.log(eventType, eventData);
});

WARNING

在这段代码中,我们假设 "消息 "事件只由本地应用程序发送,但在实际应用中,这并不总是正确的。 此外,我们没有检查 data 是否真的属于 类型 string。 不要忘记检查每种类型,并适当处理传入的事件。

电脑、手机和 Windows Phone

桌面版、手机版和 Windows Phone 版 Telegram 不使用 上一节所述的方法。他们的做法有点不同寻常。开发者首先要知道的是,如果 Telegram 需要发布事件,它会插入 JavaScript 代码,调用全局定义的函数。

下面就是一个例子:

typescript
window.Telegram.WebView.receiveEvent('popup_closed', {
  button_id: 'cancel'
});

该功能的路径取决于平台:

  • window.TelegramGameProxy.receiveEvent - Telegram 桌面版;
  • window.Telegram.WebView.receiveEvent - 适用于 iOS 和 Android 的 Telegram;
  • window.TelegramGameProxy_receiveEvent - Windows Phone

所有这些函数都有相同的签名:

typescript
type ReceiveEvent = (eventType: string, eventData: unknown) => void;

因此,解决办法相当简单。 为了处理传入的事件,我们应该创建一个 类型的函数,并将其分配给所有 3 条路径。

监听事件

为开发人员的应用程序处理所有可能的环境是一项挑战。 为了简化 这一过程,社区开发了 @telegram-apps/sdk 软件包,大大简化了集成工作。

下面介绍如何使用它:

ts
import { on } from '@telegram-apps/sdk';

// 开始监听 "viewport_changed "事件。
// 返回值是一个函数,用于移除此事件监听器。
const removeListener = on('viewport_changed', payload => {
  console.log('Viewport changed:', payload);
});

// 移除此事件监听器。
removeListener();

有关调用方法的更多信息,请参阅 软件包的 documentation

可用事件

本节包含从 Telegram 发送的事件列表:名称、描述和参数。 参数。部分标题表示最小版本,该部分内的事件可从该版本发送。

back_button_pressed

启用版本: v6.1

用户点击了 返回按钮

biometry_auth_requested

启用版本: v7.2

生物测量认证请求已完成。 该事件通常发生在对 web_app_request_auth 方法的响应中。

如果身份验证成功,事件中就会包含一个来自本地安全存储的令牌。

字段类型说明
status'failed''authorized'验证状态。
tokenstring可选。 之前保存的本地安全存储器中的令牌。 仅当 statusauthorized 时通过。

biometry_info_received

启用版本: v7.2

生物测量设置已收到。

字段类型说明
availableboolean显示是否提供生物测量。
access_requestedboolean显示是否已申请使用生物识别技术的权限。
access_grantedboolean显示是否已批准使用生物识别技术。
device_idstring唯一的设备标识符,可用于将令牌与设备进行匹配。
token_savedboolean显示本地安全存储是否包含以前保存的令牌。
type'face''finger'设备上当前可用的生物识别技术类型。

biometry_token_updated

启用版本: v7.2

生物计量令牌已更新。

字段类型说明
status'updated''removed'更新状态。

clipboard_text_received

启用版本: v6.4

Telegram 应用程序试图从剪贴板提取文本。

字段类型说明
req_idstring在调用 web_app_read_text_from_clipboard 方法时传递的 req_id 值。
datastringnull可选。 从剪贴板中提取的数据。 只有在应用程序可以访问剪贴板的情况下,返回值才会是 string 类型。

custom_method_invoked

启用版本: v6.9

自定义方法调用完成。

字段类型说明
req_idstring本次调用的唯一标识符。
resultunknown可选。 方法调用成功。
errorstring可选。 方法调用错误代码。

invoice_closed

账单已结清。

字段类型说明
slugstring 在  期间传递 web_app_open_invoice  方法调用的slug值。
statusstring 账单状态。 值:
  • paid,账单已支付
  • failed,账单失败
  • pending,账单目前待定
  • cancelled,账单已取消

main_button_pressed

用户点击了 主按钮

phone_requested

启用版本: v6.9

申请已收到电话访问请求状态。

字段类型说明
statusstring请求状态。只能是 sentcancelled

Popup 已关闭。

字段类型说明
button_idstring可选。 被点击按钮的标识符。 如果弹出窗口关闭时没有点击任何按钮,则省略此属性。

reload_iframe

父 iframe 请求重新加载当前 iframe。

qr_text_received

启用版本: v6.4

QR 扫描仪扫描一些 QR 并提取其内容。

字段类型说明
datastring可选。 从 QR 中提取的数据。

scan_qr_popup_closed

启用版本: v6.4

QR 扫描仪已关闭。

secondary_button_pressed

启用版本: v7.10

用户点击了辅助按钮。

set_custom_style

通常由 Telegram 网络应用程序发送的事件。 其有效载荷代表 <style/> 标记 HTML 内容,开发人员可以使用。 有效载荷中描述的样式表将帮助 开发人员设计应用程序滚动条的样式(但开发人员仍可自行设计)。

settings_button_pressed

启用版本: v6.1

按下 设置按钮 时出现。

theme_changed

每当用户的 Telegram 应用程序(包括切换到夜间模式)中的主题 发生更改时都会出现这种情况。

字段类型说明
theme_paramsRecord<string, string>映射,其中键是主题样式表键,值是以 #RRGGBB 格式表示的相应颜色。

viewport_changed

viewport 发生更改时出现。 例如,当用户开始拖动应用程序或调用扩展方法时。

字段类型说明
heightnumber视口高度。
widthnumber可选。 视口宽度。
is_expandedboolean当前视口是否已展开。
is_state_stableboolean视口当前状态是否稳定,下一秒是否会改变。

TIP

请注意,这种方法的发送速率不足以平滑调整 应用程序窗口的大小。 您可能应该使用一个稳定的高度来代替当前的高度,或者用其他方法来处理 这个问题。

write_access_requested

启用版本: v6.9

应用程序收到的写入访问请求状态。

字段类型说明
statusstring请求状态。只能是 allowedcancelled

Released under the MIT License.