首页 > 解决方案 > Array.splice() 产生值“未定义”

问题描述

目前,我正在研究应该从列表中删除用户选择的选项的代码。当我使用该.splice()方法时,它会产生 value undefined

最初我认为这是一个异步问题,所以我为此添加了异步代码。

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?`)
})

我的预期结果是该函数返回一个没有用户选择选项的数组。此时,该值为“未定义”并破坏代码。

标签: javascriptarraysnode.jsactions-on-google

解决方案


我不得不硬编码一些值并删除您的值,app.intent("Optionpicker", (conv, input) => {因为在此示例中未定义 app、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);
});


推荐阅读