在JavaScript中以键对象的数组格式插入值

时间:2018-06-13 07:43:24

标签: javascript arrays object

我正在尝试将数组(带有电子邮件地址)转换为对象。 如何在一个键的值数组中插入值?

var list = [
  "john@yahoo.com", "rami@gmail.com",
  "josh@yahoo.com", "bale@gmail.com"
];

(function() {
  var obj1 = {};
  for (var a = 0, b = list.length; b > a; a++) {
    var str = list[a].split("@");
    var arr = [];
    arr.push(str[0]);
    if (!(str[1] in obj1)) {
      obj1[str[1]] = []; //arr.push(str[0])];
    }

    Object.values(obj1[str[1]]).push(str[0])

  };
  console.log(obj1);
})();
<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script>
预期产出

    {
    "gmail.com" : ["a","b","c"],
    "yahoo.com" : ["de","e","f"]
    }

我也想添加像

    {
    "gmail.com" : [3],//1+1+1
    "yahoo.com" : [4]//1+1+1+1
    }

4 个答案:

答案 0 :(得分:1)

var list = [
  "john@yahoo.com", "rami@gmail.com",
  "josh@yahoo.com", "bale@gmail.com"
];
obj = {};
list.map(x => x.split('@')[1]).forEach(x => obj[x] = [])
list.forEach(email => obj[email.split('@')[1]].push(email))
console.log(obj)
/*
{
  "yahoo.com": [
"john@yahoo.com",
"josh@yahoo.com"
  ],
  "gmail.com": [
"rami@gmail.com",
"bale@gmail.com"
  ]
}
*/

<强>解释: 创建了一个空白对象obj。然后我迭代list并按list.map(x => x.split('@')[1])检索所有域。

有了域名,我设置了对象以具有结构{ 'yahoo.com': [], 'gmail.com': [] }

然后我再次迭代列表并添加电子邮件,如果域包含相应的部分,给出结果对象。

修改: 它也可以通过这种方式在单次迭代中完成:

var list = [
  "john@yahoo.com", "rami@gmail.com",
  "josh@yahoo.com", "bale@gmail.com"
]
obj = {}
list.forEach(email => {
  let domain = email.split('@')[1]
  if (!obj[domain]) obj[domain] = []
  if (obj[domain].indexOf(email) < 0) obj[domain].push(email)
})
console.log(obj)

在这里,我正在迭代列表,提取域名,设置密钥[]如果它不存在,然后将电子邮件推入其中。它还确保不会推送重复的电子邮件。

答案 1 :(得分:0)

如果在对象中找到键,则可以简单地按下数组中的值,否则添加数组

port
var list = [
  "john@yahoo.com", "rami@gmail.com",
  "josh@yahoo.com", "bale@gmail.com"
];

(function() {
  var obj1 = {};
  for (var a = 0; a < list.length;  a++) {
    var str = list[a].split("@");
    if(obj1[str[1]]) {
        obj1[str[1]].push(list[a])
    } else {
        obj1[str[1]] = [list[a]]; //arr.push(str[0])];
    }
  };
  console.log(obj1);
})();

答案 2 :(得分:0)

你的代码几乎是正确的,只有一个小错误,改变你的行:

Object.values(obj1[str[1]]).push(str[0])

obj1[str[1]].push(list[a]);

它运作正常。

var list = [
  "john@yahoo.com", "rami@gmail.com",
  "josh@yahoo.com", "bale@gmail.com"
];

(function() {
  var obj1 = {};
  for (var a = 0, b = list.length; b > a; a++) {
    var str = list[a].split("@");
    var arr = [];
    arr.push(str[0]);
    if (!(str[1] in obj1)) {
      obj1[str[1]] = []; //arr.push(str[0])];
    }

    obj1[str[1]].push(list[a]);

  };
  console.log(obj1);
})();
<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script>

答案 3 :(得分:0)

Array.prototype.reduce通常用于将array数据翻译为object表单。

见下面的实际例子

// Emails.
const emailAddresses = ["bale@gmail.com", "john@yahoo.com", "rami@gmail.com","josh@yahoo.com"]

// Group By Domain.
const groupByDomain = addresses => addresses.reduce((acc, email) => {
  const [prefix, domain] = email.split(/@/)
  const exists = acc[domain]
  if (exists) acc[domain].push(email)
  else acc[domain] = [email]
  return acc
}, {})

// Output.
const output = groupByDomain(emailAddresses)

// Proof.
console.log(output)