变量在for循环内不变

时间:2020-08-25 00:06:40

标签: javascript arrays object

我正在尝试创建一个函数,该函数检查键(name1,name2)之一是否存在,然后将其值分配给变量。

如果确实存在且名称为1,则将“ left”分配给变量section。如果是name2,则将“正确”分配给变量section

但是现在,我只看到value被更新,但是section仍然位于“左侧”,即使obj中只有name2。

const obj = {name1: "John", name2: "Jane"};

for (var key of Object.keys(obj)) {
  let value = '';
  let section = '';

  if (name1) {
   value = (Object.entries(obj)[0][1]);
   section = "left";
  } else if (name2) {
   value = (Object.entries(obj)[0][1]);
   section = "right";
  }

  value = Object.assign({}, {value, section});

  console.log(value);
}

2 个答案:

答案 0 :(得分:0)

您的变量name1和name2没有在循环中定义。

您应该将它们替换为对字符串的测试。

const obj = {name1: "John", name2: "Jane"};

for (var key of Object.keys(obj)) {
  let value = '';
  let section = '';

  if (key == "name1") {
   value = (Object.entries(obj)[0][1]); // element 0 of Object.entries(obj), "John"
   section = "left";
  } else if (key == "name2") {
   value = (Object.entries(obj)[1][1]); // element 1 of Object.entries(obj), "Jane"
   section = "right";
  }

  value = Object.assign({}, {value, section});

  console.log(value);
}

但是您的代码太复杂了,您可以将其替换为更简单的版本:

const obj = {name1: "John", name2: "Jane"};

for (var key in obj) {

  if (key === "name1") {
   obj['section'] = 'left';
   break;
  } else if (key === "name2") {
   obj['section'] = 'right';
   break;
  }
}

//move the console log outside the loop
console.log(obj);

编辑:我忘了打破循环

答案 1 :(得分:0)

循环中的值没有改变,因为您要保存Object.entries(obj)输出的第0个元素的第1个元素。这意味着无论节是“左”还是“右”,您总是会得到“约翰”。

const obj = {name1: "John", name2: "Jane"};

for (var key of Object.keys(obj)) {
  let value = {};

  if (key === "name1") {
   value.value = obj[key]; // key is "name1", obj[key] == "John"
   value.section = "left";
  } else if (key === "name2") {
   value.value = obj[key]; // key is "name2", obj[key] == "Jane"
   value.section = "right";
  }

  console.log(value);
}

这应该是您想要的输出。

如果这是您应该使用Object方法的练习,或者如果您事先不知道属性名称,请对此答案发表评论,然后我会对其进行调整。