Node.js 自适应卡和Microsoft Bot框架:仅允许';openUrl';行动?
编辑2:以下模式(由同事提供)有效。我从微软的示例中删除了模式中的引号,但仍然不起作用。我不确定是什么问题。我把这个问题留着,以防其他人想提供答案,但我已经找到了答案Node.js 自适应卡和Microsoft Bot框架:仅允许';openUrl';行动?,node.js,botframework,adaptive-cards,Node.js,Botframework,Adaptive Cards,编辑2:以下模式(由同事提供)有效。我从微软的示例中删除了模式中的引号,但仍然不起作用。我不确定是什么问题。我把这个问题留着,以防其他人想提供答案,但我已经找到了答案 const card = { contentType: 'application/vnd.microsoft.card.adaptive', content: { $schema: 'http://adaptivecards.io/schemas/adaptive-card.
const card = {
contentType: 'application/vnd.microsoft.card.adaptive',
content: {
$schema: 'http://adaptivecards.io/schemas/adaptive-card.json',
type: 'AdaptiveCard',
version: '1.0',
{
type: 'Input.Text',
placeholder: 'Name',
style: 'text',
maxLength: 50,
id: 'defaultInput'
},
actions: [
{
type: 'Action.Submit',
title: 'Siguiente',
data: {} // will be populated with form input values
}
]
}
};
我正在尝试使用自适应卡在我的MS机器人中创建一个表单。我从MS站点()获取了示例表单,但出现以下错误
错误似乎认为我的操作类型是action.openUrl
,但我在下面的代码中没有看到。非常感谢您的帮助。使用Microsoft Bot Framework 3,节点12.13.0
function askPolicyNumber(session) {
const card = {
'$schema': 'https://adaptivecards.io/schemas/adaptive-card.json',
'type': 'AdaptiveCard',
'version': '1.1',
'body': [
{
'type': 'Input.Text',
'id': 'id_text'
},
{
'type': 'Input.Number',
'id': 'id_number'
}
],
'actions': [
{
'type': 'Action.messageBack',
'title': 'Submit',
'data': {
'prop1': true,
'prop2': []
}
}
]
};
const msg = new builder.Message(session).attachments([card]);
return session.send(msg);
}
编辑:
似乎无论我设置了什么动作,它都一直认为这是一个openUrl
动作。事实上,如果我将它设置为openUrl
,并给它一个url
属性,它就可以正常工作
我看了这一页-,并按照“带messageBack操作的自适应卡”的说明进行操作,但它没有改变任何东西
"actions": [
{
"type": "Action.Submit",
"title": "Click me for messageBack",
"data": {
"msteams": {
"type": "messageBack",
"displayText": "I clicked this button",
"text": "text to bots",
"value": "{\"bfKey\": \"bfVal\", \"conflictKey\": \"from value\"}"
}
}
}
]
}
你所做的有很多问题。建议每个人都使用Bot Builder v4而不是v3。您的同事解决的主要问题是,您试图将自适应卡对象当作附件对象来使用
您链接到的博客文章解释了自适应卡必须遵循自适应卡模式。自适应卡架构中没有
操作.messageBack
。请继续参考文档以获取更多信息。我正在一个大型框架内工作,他们正在将其迁移到v.4,但目前我必须使用v.3,这不是我的选择。。。