javascript - 如何清除用户存储(Dialogflow)
问题描述
我在我的用户存储中存储了一个值(在我的情况下,用户想要听到新闻的城市)。我希望用户能够改变这个城市,从而改变用户存储。我已经尝试了很多东西,但还没有让它工作,希望有人能提供帮助。
当用户选择更改城市时,会调用regio_kiezen意图。此意图使用包含多个城市的名为regio的实体询问您想要哪个城市。请参阅此意图的屏幕截图(顺便说一句:为调用此意图的另一个场景添加事件):
在提示输入参数值后,它会转到履行。这是此意图和称为 Regio 的意图的实现代码(这是显示新闻标题的意图):
app.intent('regio_kiezen', (conv, params) => {
conv.user.storage.regio = {};
var chosen_regio = params['regio'];
conv.user.storage.regio = chosen_regio;
console.log(`user: ${conv.user.storage.regio}`);
conv.followup('Regio');
console.log("intent: regio kiezen intent");
});
app.intent('Regio', (conv) => {
console.log("regio intent");
console.log(`doebiesnoesje: ${conv.user.storage.regio}`);
conv.ask(new Suggestions('Regio veranderen'));
conv.ask(new Suggestions(['Suggestion 2', 'Suggestion 3']));
return axios.get(`api-adress/${conv.user.storage.regio}`) //can not share the real api-adres
.then((result) => {
// informatie ophalen
for (let i=0; i <= 5; i++) {
titels[i] = (result.data.categories[0].news[i].title); // titel
subtexts[i] = (result.data.categories[0].news[i].text); // subtext
images[i] = (result.data.categories[0].news[i].media[0].image); // image
links[i] = (result.data.categories[0].news[i].url); // link
}
// LIST
if (!conv.screen) {
conv.ask('Sorry, try this on a screen device or select the ' +
'phone surface in the simulator.');
return;
}
console.log(`Regioo:`);
if(conv.user.storage.regio == 'nhgooi') {
praat = 'het Gooi';
} else {
praat = conv.user.storage.regio;
}
conv.ask(`Hier volgt het laatste nieuws uit ${praat}`);
conv.ask(new List({
title: praat,
items: {
// Add the first item to the list
'SELECTION_KEY_ONE': {
synonyms: [
'synonym 1',
'synonym 2',
'synonym 3',
],
title: titels[0],
image: new Image({
url: images[0],
}),
},
// Add the second item to the list
'SELECTION_KEY_GOOGLE_HOME': {
synonyms: [
'Google Home Assistant',
'Assistant on the Google Home',
],
title: titels[1],
image: new Image({
url: images[1],
}),
},
// Add the third item to the list
'SELECTION_KEY_GOOGLE_PIXEL': {
synonyms: [
'Google Pixel XL',
'Pixel',
'Pixel XL',
],
title: titels[2],
image: new Image({
url: images[2],
}),
},
'SELECTION_FOUR': {
synonyms: [
'Google Pixel XL',
'Pixel',
'Pixel XL',
],
title: titels[3],
image: new Image({
url: images[3],
}),
},
'SELECTION_KEY_FIVE': {
synonyms: [
'Google Pixel XL',
'Pixel',
'Pixel XL',
],
title: titels[4],
image: new Image({
url: images[4],
}),
},
},
}));
})
.catch((err) => console.log(err));
});
我遇到的问题是它一直显示旧(第一组)城市的新闻。因此,看起来 conv.user.storage.regio 没有被更改。我不知道为什么会这样,希望有人能提供帮助!提前致谢。
解决方案
感谢所有的评论。我找到了解决方案。当意图 2 发生时,在意图 1 中看不到清除用户存储或更新。起作用的是在 regio_kiezen 意图中创建新的用户存储变量。创建一个全局变量来存储这个值。在 Regio 意图中检查这个变量是否未定义并选择选择用户存储或创建的变量。我知道这可能不是很清楚,所以请看一下代码:
app.intent('regio_kiezen', (conv, params) => {
console.log(`user1: ${conv.user.storage.regio}`);
p = 0;
r++;
conv.user.storage.regio = '';
conv.user.storage.regio = params['regio'];
test = conv.user.storage.regio;
test2 = params['regio'];
conv.user.storage.regio2 = test2;
tert = conv.user.storage.regio2;
console.log("testt: " + test + " test2: " + test2);
console.log(`tert: ${conv.user.storage} en ${conv.user.storage.regio2} en ${tert}`);
conv.followup('Regio');
console.log("intent: regio kiezen intent");
return tert;
});
app.intent('Regio', (conv) => {
p++;
console.log("regio intent");
console.log(`tertt: ${conv.user.storage.regio2} en ${tert}`);
//console.log("test: " + test + " test2: " + test2);
console.log(`doebiedushi: ${conv.user.storage.regio}`);
if (tert === undefined) {
var regioo = conv.user.storage.regio;
} else {
var regioo = tert;
}
conv.ask(new Suggestions(['Regio veranderen', 'Meer nieuws']));
return axios.get(`https:url/${regioo}`)
.then((result) => { //rest of code
这有效并存储在会话和对话之间!
推荐阅读
- https - 如何购买和申请 https 认证
- r - 如何查找传递给函数的对象名称
- c# - 在我尝试创建 ASP.NET MVC 项目时,创建标识时出现脚手架项目错误
- python-3.x - 如何执行带有python输入的shell程序?
- spring - Eureka:两台服务器 - 一台宕机
- javascript - 如何在不先加载原始文本的情况下替换网页上的文本?
- java - 使用蚂蚁模式匹配路径变量
- javascript - Facebook Share Dialog "media" parameter?
- palantir-foundry - 在 Palantir Foundry 的 Workshop 中,如何清除我之前保存的默认 Workshop 变量值?
- reactjs - SwiperJS - ReactJS carousel mixed with videos and images double sounded