小程序
💠组件 负责管理 Telegram 小程序内的功能。
挂载
在使用该组件之前,必须使用 mount
方法挂载该组件,该方法会更新 isMounted
信号属性。
ts
import { miniApp } from '@telegram-apps/sdk';
if (miniApp.mount.isAvailable()) {
miniApp.mount();
miniApp.isMounted(); // true
}
ts
import { mountMiniApp, isMiniAppMounted } from '@telegram-apps/sdk';
if (mountMiniApp.isAvailable()) {
mountMiniApp();
isMiniAppMounted(); // true
}
INFO
mount
方法还会挂载 Theme Params作用域,以提取正确的 配置值。
要卸载组件,请使用 unmount
方法:
ts
miniApp.unmount();
miniApp.isMounted(); // false
ts
import { unmountMiniApp, isMiniAppMounted } from '@telegram-apps/sdk';
unmountMiniApp();
isMiniAppMounted(); // false
绑定 CSS 变量
要通过 CSS 变量公开 miniApp
属性,请使用 bindCssVars
方法。 调用该方法后,isCssVarsBound
信号属性会被更新。 调用该方法后,isCssVarsBound
信号属性会被更新。
此方法可选择接受一个函数,该函数可将 bgColor
和 headerColor
的值转换为 CSS 变量名。 默认情况下,数值会以前缀 --tg-
转换为 kebab 大小写。
ts
if (miniApp.bindCssVars.isAvailable()) {
miniApp.bindCssVars();
// Creates CSS variables like:
// --tg-bg-color: #aabbcc
// --tg-header-color: #aabbcc
miniApp.bindCssVars(key => `--my-prefix-${key}`);
// Creates CSS variables like:
// --my-prefix-bgColor: #aabbcc
// --my-prefix-headerColor: #aabbcc
miniApp.isCssVarsBound(); // true
}
ts
import { bindMiniAppCssVars, isMiniAppCssVarsBound } from '@telegram-apps/sdk';
if (bindMiniAppCssVars.isAvailable()) {
bindMiniAppCssVars();
// Creates CSS variables like:
// --tg-bg-color: #aabbcc
// --tg-header-color: #aabbcc
bindMiniAppCssVars(key => `--my-prefix-${key}`);
// Creates CSS variables like:
// --my-prefix-bgColor: #aabbcc
// --my-prefix-headerColor: #aabbcc
isMiniAppCssVarsBound(); // true
}
页眉颜色(Header Color)
要更改小程序的标题颜色,可使用方法 setHeaderColor
。 反过来, 会更新 headerColor
信号属性值。 而这反过来, 会更新 headerColor
信号属性值。
该方法接受 RGB 颜色值或以下字符串之一:bg_color
、secondary_bg_color
。
ts
if (miniApp.setHeaderColor.isAvailable()) {
miniApp.setHeaderColor('bg_color');
miniApp.headerColor(); // 'bg_color'
}
if (
miniApp.setHeaderColor.isAvailable()
&& miniApp.setHeaderColor.supports('rgb')
) {
miniApp.setHeaderColor('#aabbcc');
miniApp.headerColor(); // '#aabbcc'
}
ts
import {
setMiniAppHeaderColor,
miniAppHeaderColor,
} from '@telegram-apps/sdk';
if (setMiniAppHeaderColor.isAvailable()) {
setMiniAppHeaderColor('bg_color');
miniAppHeaderColor(); // 'bg_color'
}
if (
setMiniAppHeaderColor.isAvailable()
&& setMiniAppHeaderColor.supports('rgb')
) {
setMiniAppHeaderColor('#aabbcc');
miniAppHeaderColor(); // '#aabbcc'
}
背景颜色
要更新小程序的背景颜色,请使用 setBackgroundColor
方法。 调用 时,该方法会更新 headerColor
信号属性值。
ts
if (miniApp.setBackgroundColor.isAvailable()) {
miniApp.setBackgroundColor('#ffffff');
miniApp.backgroundColor(); // '#ffffff'
}
ts
import {
setMiniAppBackgroundColor,
miniAppBackgroundColor,
} from '@telegram-apps/sdk';
if (setMiniAppBackgroundColor.isAvailable()) {
setMiniAppBackgroundColor('#ffffff');
miniAppBackgroundColor(); // '#ffffff'
}
方法
close
要关闭小程序,请使用 close
方法。
ts
if (miniApp.close.isAvailable()) {
miniApp.close();
}
ts
import { closeMiniApp } from '@telegram-apps/sdk';
if (miniApp.close.isAvailable()) {
miniApp.close();
}
ready
要发出 小程序已准备好显示的信号,请使用 ready
方法。 调用后, 加载占位符会被隐藏,而小程序则会显示出来。 调用后, 加载占位符会被隐藏,而小程序则会显示出来。
ts
if (miniApp.ready.isAvailable()) {
miniApp.ready();
}
ts
import { miniAppReady } from '@telegram-apps/sdk';
if (miniAppReady.isAvailable()) {
miniAppReady();
}
TIP
在加载基本界面元素后尽早调用该函数,以确保 顺畅的用户体验。