如何解决自适应卡片模板在 Composer 中是否有效?
我想像这样向自适应卡片添加按钮:
"actions": [
{
"$data": "${collection}","type": "Action.Submit","title": "${prop1}","data": {
"value": "${prop2}"
}
}
],
这在 https://adaptivecards.io/designer/
中运行良好但在 Composer 中的 .lg 文件中却没有。
为了让它起作用:
"$data": "${collection}",
我需要删除 ${collection} 周围的引号。
但是我没有办法让每个项目的 prop1 和 prop2 显示工作。当您在 $data 字段中声明一个带有数组的元素时,该元素应该被重复,然后绑定的属性将属于该数组的每个元素。这也没有发生。
我开始认为 Composer 不支持模板,我需要替换这些值并使用 lg 语法做一个映射。
解决方法
简短回答:否
机器人需要通过使用 Adaptive Cards templating 库向模板应用数据来明确“扩展”模板。 Composer 源代码从未提及自适应卡片,并且在整个 Bot Builder .NET SDK 中唯一提到的自适应卡片是附件内容被识别为自适应卡片的地方,因此可以应用正确的内容类型。 Composer 和 Bot Builder 甚至都不依赖 Adaptive Cards SDK,更不用说 Adaptive Cards 模板库了。
这个问题的某种形式已经在 GitHub 上被问过几次了:
- https://github.com/microsoft/BotFramework-Composer/issues/3798
- https://github.com/microsoft/BotFramework-Composer/issues/3422
- https://github.com/microsoft/BotFramework-Composer/issues/2129
您有几个选择:
- 如那些 GitHub 问题中所述,使用 Bot Framework LG 的内置数据绑定功能,而不是依赖于自适应卡片模板
- Export the Composer runtime 这样您就可以像使用普通机器人一样向其添加功能
- 正式feature request要求 Composer 团队将自适应卡片模板整合到 Composer 中
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。