Array.splice() 结果值 'undefined'
Array.splice() results in the value 'undefined'
目前,我正在研究应该从列表中删除用户选择的选项的代码。当我使用 .splice()
方法时,它会产生值 undefined
。
一开始以为是async的问题,所以加了async的代码。
app.intent("Optionpicker", (conv, input) => {
conv.data.list = ['optionA', 'optionB', 'optionC', 'optionD']
let choice = conv.parameters.choice
async function listremover() {
let index = conv.data.list.indexOf(choice);
if (index > -1) {
conv.data.list = conv.data.list.splice(index, 1);
return conv.data.list
}
}
listremover().then()
conv.add(`Ok, your choice is ${choice}. The remaining options are: ${conv.data.list[0]}, ${conv.data.list[1]} and ${conv.data.list[2]}. Which one is next?`)
})
我的预期结果是函数 returns 一个没有用户选择选项的数组。此时值为'undefined',crshes代码
我不得不对一些值进行硬编码并删除你的 app.intent("Optionpicker", (conv, input) => {
因为应用程序、转换和输入在此示例中未定义。
let conv = {};
//let choice = 2; // conv.parameters.choice;
// had to hard code values b/c app and conv are undefined in this example
conv.data = {};
conv.data.list = ['optionA', 'optionB', 'optionC', 'optionD'];
let selected = {};
async function listremover() {
let index = conv.data.list.indexOf('optionB');
//if (index > -1) {
//conv.data.list = conv.data.list.splice(index, 1);
//return conv.data.list;
//}
if (index > -1) {
selected = conv.data.list.splice(index, 1);
//return selected; // returns selected array
}
return conv.data.list; // returns remaining values of original array
}
listremover().then(function(res) {
// removed `conv.add()` not sure where this is defined...
//console.log(`Ok, your choice is ${selected}. The remaining options are: ${conv.data.list[0]}, ${conv.data.list[1]} and ${conv.data.list[2]}. Which one is next?`);
console.log(res);
});
目前,我正在研究应该从列表中删除用户选择的选项的代码。当我使用 .splice()
方法时,它会产生值 undefined
。
一开始以为是async的问题,所以加了async的代码。
app.intent("Optionpicker", (conv, input) => {
conv.data.list = ['optionA', 'optionB', 'optionC', 'optionD']
let choice = conv.parameters.choice
async function listremover() {
let index = conv.data.list.indexOf(choice);
if (index > -1) {
conv.data.list = conv.data.list.splice(index, 1);
return conv.data.list
}
}
listremover().then()
conv.add(`Ok, your choice is ${choice}. The remaining options are: ${conv.data.list[0]}, ${conv.data.list[1]} and ${conv.data.list[2]}. Which one is next?`)
})
我的预期结果是函数 returns 一个没有用户选择选项的数组。此时值为'undefined',crshes代码
我不得不对一些值进行硬编码并删除你的 app.intent("Optionpicker", (conv, input) => {
因为应用程序、转换和输入在此示例中未定义。
let conv = {};
//let choice = 2; // conv.parameters.choice;
// had to hard code values b/c app and conv are undefined in this example
conv.data = {};
conv.data.list = ['optionA', 'optionB', 'optionC', 'optionD'];
let selected = {};
async function listremover() {
let index = conv.data.list.indexOf('optionB');
//if (index > -1) {
//conv.data.list = conv.data.list.splice(index, 1);
//return conv.data.list;
//}
if (index > -1) {
selected = conv.data.list.splice(index, 1);
//return selected; // returns selected array
}
return conv.data.list; // returns remaining values of original array
}
listremover().then(function(res) {
// removed `conv.add()` not sure where this is defined...
//console.log(`Ok, your choice is ${selected}. The remaining options are: ${conv.data.list[0]}, ${conv.data.list[1]} and ${conv.data.list[2]}. Which one is next?`);
console.log(res);
});