在 Adaptive Card SDK 中,文本块(TextBlock)可以设置颜色(Color)和权重(Weight)属性,但是在解析 Adaptive Card JSON 时,SDK 并不会自动解析并设置这些属性。需要手动解析 JSON 中的相应字段并设置属性。以下是示例代码:
// 导入 Adaptive Card SDK
import * as AdaptiveCards from "adaptivecards";
// 获取 JSON 字符串
const jsonString = '{ "type": "TextBlock", "text": "Hello world", "color": "Accent", "weight": "Bolder" }';
// 解析 JSON
const element = AdaptiveCards.AdaptiveCard.elementTypeRegistry.createInstance("TextBlock");
const jsonPayload = JSON.parse(jsonString);
element.parse(jsonPayload);
// 设置颜色和权重
const textBlock = element as AdaptiveCards.TextBlock;
textBlock.color = AdaptiveCards.getEnumValueOrDefault(AdaptiveCards.ForegroundColor, jsonPayload.color, AdaptiveCards.ForegroundColor.Default);
textBlock.weight = AdaptiveCards.getEnumValueOrDefault(AdaptiveCards.TextWeight, jsonPayload.weight, AdaptiveCards.TextWeight.Default);
在以上示例中,首先使用 AdaptiveCard.elementTypeRegistry.createInstance()
创建一个类型为 TextBlock
的元素实例,然后解析传入的 JSON 字符串并将其赋值给元素实例的 parse()
方法。最后,我们将元素实例转换为 TextBlock
类型,并手动设置其颜色和权重属性。其中,AdaptiveCards.getEnumValueOrDefault()
方法用于将字符串值转换成对应的枚举值。