Skip to content

标准元素

基础元素

基本元素是最常见的消息元素,它们能够在大多数平台上正常显示,是组成消息的基本单位。

提及用户 (at)

属性类型范围描述
idstring?收发目标用户的 ID
namestring?收发目标用户的名称
rolestring?收发目标角色
typestring?收发特殊操作,例如 all 表示 @全体成员,here 表示 @在线成员

<at> 元素用于提及某个或某些用户。

提及频道 (sharp)

属性类型范围描述
idstring收发目标频道的 ID
namestring?收发目标频道的名称

<sharp> 元素用于提及某个频道。

链接 (a)

属性类型范围描述
hrefstring收发链接的 URL

<a> 元素用于显示一个链接。当平台不支持链接时,建议显示为 content (href) 的形式。

资源元素

资源消息元素表示文本中存在的资源文件。不同的平台对资源文件的支持存在较大的差异。发送时只需提供 src。如果某个平台不支持特定的资源类型,适配器应该用 src 代替。如果某个平台不支持将资源消息元素和其他消息元素同时发送,适配器应该分多条发送。

属性类型范围描述
srcstring收发资源的 URL
titlestring?收发资源文件名称
cache 实验性boolean?是否使用已缓存的文件
timeout 实验性number?下载文件的最长时间 (毫秒)

图片 (img)

除了上述通用属性外,还支持下面的属性:

属性类型范围描述
widthnumber?图片宽度 (像素)
heightnumber?图片高度 (像素)

<img> 元素用于表示图片。

音频 (audio)

除了上述通用属性外,还支持下面的属性:

属性类型范围描述
durationnumber?收发音频长度 (秒)
posterstring?收发音频封面 URL

<audio> 元素用于表示语音。

视频 (video)

除了上述通用属性外,还支持下面的属性:

属性类型范围描述
widthnumber?视频宽度 (像素)
heightnumber?视频高度 (像素)
durationnumber?视频长度 (秒)
posterstring?收发视频封面 URL

<video> 元素用于表示视频。

文件 (file)

除了上述通用属性外,还支持下面的属性:

属性类型范围描述
posterstring?收发缩略图 URL

<file> 元素用于表示文件。

修饰元素

修饰元素用于修饰其中的内容。如果对应的平台不支持对应的元素,可以忽略这个元素本身,正常渲染其中的子元素。

粗体 (b, strong)

<b><strong> 元素用于将其中的内容以粗体显示。

斜体 (i, em)

<i><em> 元素用于将其中的内容以斜体显示。

下划线 (u, ins)

<u><ins> 元素用于为其中的内容附加下划线。

删除线 (s, del)

<s><del> 元素用于为其中的内容附加删除线。

剧透 (spl)

<spl> 元素用于将其中的内容标记为剧透 (默认会被隐藏,点击后才显示)。

代码 (code)

<code> 元素用于将其中的内容以等宽字体显示 (通常还会有特定的背景色)。

上标 (sup)

<sup> 元素用于将其中的内容以上标显示。

下标 (sub)

<sub> 元素用于将其中的内容以下标显示。

排版元素

换行 (br)

<br> 元素表示一个独立的换行。

段落 (p)

<p> 元素表示一个段落。在渲染时,它与相邻的元素之间会确保有一个换行。

消息 (message)

属性类型范围描述
idstring?消息的 ID
forwardboolean?是否为转发消息

<message> 元素的基本用法是表示一条消息。子元素对应于消息的内容。如果其没有子元素,则消息不会被发送。

当出现 <message> 元素时,之前的元素会被立即视为一条消息被发送。因此下面的两种写法是等价的:

html
<!-- 第一种写法:发送两条消息 -->
<message>hello</message>
<message>world</message>

<!-- 第二种写法:用一条空消息隔开两段文本,实际上仍然会发送两条消息 -->
hello<message/>world

部分平台允许你模拟其他用户发送消息:

html
<message>
  <author id="123123123" name="Alice" avatar="url"/>
  hello world
</message>

在支持转发的平台上,你可以使用 forward 配合 id 属性来转发一条消息:

html
<message id="123456789" forward/>

在支持合并转发的平台上,你可以使用带有 forward 属性的 <message> 元素嵌套其他 <message> 元素来实现合并转发:

html
<message forward>
  <message id="123456789"/>
  <message id="987654321"/>
  <!-- 合并转发里也可以嵌套模拟其他用户发送的消息 -->
  <message>
    <author id="123123123" name="Alice" avatar="url"/>
    hello world
  </message>
</message>

元信息元素

元信息元素通常不会被渲染,但会影响到消息的发送行为。

引用 (quote)

<quote> 元素用于表示对消息引用。它的子元素会被渲染为引用的内容。理论上所有 <message> 元素的特性也可以用于 <quote> 元素,包括子元素 (构造引用消息) 和 forward 属性 (引用合并转发)。然而目前似乎并没有平台提供了这样的支持。

作者 (author)

属性类型范围描述
idstring?用户 ID
namestring?昵称
avatarstring?头像 URL

<author> 元素用于表示消息的作者。它的子元素会被渲染为作者的名字。

交互元素

交互元素用于显然消息中的可交互性内容。如果平台不支持此类元素且难以提供回退,可以直接忽略整个元素。实现侧应当根据平台特性,针对性地返回带有交互和不带有交互的消息。

按钮 (button) 实验性

属性类型范围描述
idstring?按钮的 ID
typestring?按钮的类型
hrefstring?按钮的链接
textstring?待输入文本
themestring?按钮的样式

<button> 元素用于表示一个按钮。它的子元素会被渲染为按钮的文本。

按钮目前支持三种不同的类型:

  • 点击 action 类型的按钮时会触发一个 interaction/button 事件,该事件的 button 资源会包含上述 id
  • 点击 link 类型的按钮时会打开一个链接,该链接的地址为上述 href
  • 点击 input 类型的按钮时会在用户的输入框中填充上述 text

theme 仅建议使用下列值:

  • primary
  • secondary
  • success
  • warning
  • danger
  • info