我正在尝试将该onEnabled
方法与 QnAMakerRecognizer 一起使用,这样我就可以拥有多个 QnAMakerRecognizer,并且可以选择启用哪个以及禁用哪个。我已经尝试按照此示例进行操作并尝试了类似的操作,但出现错误消息:
TypeError: (中间值).onEnabled 不是函数
如何onEnable
正确使用该方法?
示例代码:
var bot = new builder.UniversalBot(connector);
var qnarecognizer1 = new cognitiveservices.QnAMakerRecognizer({
knowledgeBaseId: knowledgeId,
subscriptionKey: subscriptionId,
qnaThreshold:0.3,
top:1})
.onEnabled(function (session, callback) {
// Check to see if this recognizer should be enabled
if (session.conversationData.useqna1) {
callback(null, true);
} else {
callback(null, false);
}
});
var qnarecognizer2 = new cognitiveservices.QnAMakerRecognizer({
knowledgeBaseId: knowledgeId,
subscriptionKey: subscriptionId,
qnaThreshold:0.3,
top:1})
.onEnabled(function (session, callback) {
// Check to see if this recognizer should be enabled
if (session.conversationData.useqna2) {
callback(null, true);
} else {
callback(null, false);
}
});
var intentrecognizer = new builder.IntentDialog();
var intents = new builder.IntentDialog({ recognizers: [intentrecognizer, qnarecognizer1, qnarecognizer2] });
bot.dialog('/', intents);
intents.matches('qna', [
function (session, args, next) {
args.entities.forEach(function(element) {
session.send(element.entity);
}, this);
}
]);
intents.matchesAny([/hi/i, /main menu/i], [
function (session) {
builder.Prompts.choice(session, "Hi, What would you like to ask me about?", ["Service1","Service2"],{ listStyle: builder.ListStyle.button});
},
function (session, result) {
var selection = result.response.entity;
switch (selection) {
case "Service1":
session.conversationData.useqna1 = true;
session.conversationData.useqna2 = false;
session.send('You can now ask me anything about '+selection+'. Type \'main menu\' anytime to choose a different topic.')
session.endConversation();
return
case "Service2":
session.conversationData.useqna1 = false;
session.conversationData.useqna2 = true;
session.send('You can now ask me anything about '+selection+'. Type \'main menu\' anytime to choose a different topic.')
session.endConversation();
return
}
}
])