Skip to content

视口 - Viewport {#Viewport}

实现小程序 viewport 功能。

初始化

要初始化组件,请使用 initViewport 函数:

typescript
import { initViewport } from '@telegram-apps/sdk';

const [viewport] = initViewport();

INFO

由于 Viewport 无法同步实例化,因此该函数返回一个 promise 作为元组中的第一个 值,在检索实际视口状态时,该值将被解析。

尺寸

应用程序可以只显示小程序的上半部分,下半部分则保留在 屏幕区域之外。 从这个位置,用户可以将小程序 "拉 "到最大高度,而 开发人员也可以通过调用 expand 方法(使用isExpanded属性获取当前 的扩展状态)来完成同样的操作:

typescript
const [viewport] = initViewport();

const vp = await viewport;

if (!vp.isExpanded) {
    vp.expand(); // will expand the Mini App, if it's not
}

随着小程序位置的变化, 可视区域的当前高度值也会实时更新。

INFO

请注意,该值(height)的刷新率不足以平滑地跟踪 窗口的下边框。 不应将界面元素固定在 可视区域的底部。 为此,使用 stableHeight 字段的值更为合适。

获取实际数据

要获取实际的视口信息,开发人员可以使用 requestViewport 函数:

typescript
import {requestViewport} from '@telegram-apps/sdk';

requestViewport().then((data) => {
    // Output:
    // { height: 122, isExpanded: false, width: 375, isStateStable: true }
    console.log(data);
});

事件

可被 跟踪 的事件列表:

事件监听器触发条件
change() => void组件中的某些部分发生了变化
change:height(height: number) => voidheight 属性已更改
change:isExpanded(isExpanded: boolean) => void更改了 isExpanded 属性
change:stableHeight(stableHeight: boolean) => void更改了 stableHeight 属性
change:width(width: boolean) => void更改了 width 属性

Released under the MIT License.