登录
首页 >  文章 >  前端

JavaScript数组对象中重复ID如何处理并赋予不同值?

时间:2025-03-22 11:36:10 477浏览 收藏

学习知识要善于思考,思考,再思考!今天golang学习网小编就给大家带来《JavaScript数组对象中重复ID如何处理并赋予不同值? 》,以下内容主要包含等知识点,如果你正在学习或准备学习文章,就都不要错过本文啦~让我们一起来看看吧,能帮助到你就更好了!

JavaScript数组对象中重复ID如何处理并赋予不同值?

巧妙解决JavaScript数组对象中重复ID问题

本文提供一种高效的JavaScript方法,用于处理数组对象中重复的ID,并为具有相同ID的对象赋予不同的值。

假设我们有一个包含重复ID的数组对象:

const list = [
  { id: 1, name: '小明' },
  { id: 1, name: '小红' },
  { id: 2, name: '小强' },
  { id: 3, name: '小张' },
  { id: 4, name: '小兰' },
  { id: 1, name: '小青' },
  { id: 4, name: '小青' }
];

我们的目标是为每个重复ID的对象添加一个value属性,并赋予其不同的布尔值(true或false)。最终结果应如下所示:

const list = [
  { id: 1, name: '小明', value: true },
  { id: 1, name: '小红', value: false },
  { id: 2, name: '小强' },
  { id: 3, name: '小张' },
  { id: 4, name: '小兰', value: true },
  { id: 1, name: '小青', value: true },
  { id: 4, name: '小青', value: false }
];

为了实现这个目标,我们可以使用一个对象来跟踪ID的出现次数,并使用另一个对象记录每个ID已经赋予的值。

以下是实现代码:

const list = [
  { id: 1, name: '小明' },
  { id: 1, name: '小红' },
  { id: 2, name: '小强' },
  { id: 3, name: '小张' },
  { id: 4, name: '小兰' },
  { id: 1, name: '小青' },
  { id: 4, name: '小青' }
];

const idCounts = {};
const idValues = {};

list.forEach(item => {
  idCounts[item.id] = (idCounts[item.id] || 0) + 1;
});

list.forEach(item => {
  if (idCounts[item.id] > 1) {
    if (!idValues[item.id]) {
      idValues[item.id] = true;
    }
    item.value = idValues[item.id];
    idValues[item.id] = !idValues[item.id];
  }
});

console.log(list);

这段代码首先统计每个ID出现的次数,然后遍历数组,为重复ID的对象添加value属性,并交替赋予true和false值。 idValues 对象保证了同一个ID的后续对象会得到不同的布尔值。 这种方法简洁高效,易于理解和维护。

到这里,我们也就讲完了《JavaScript数组对象中重复ID如何处理并赋予不同值? 》的内容了。个人认为,基础知识的学习和巩固,是为了更好的将其运用到项目中,欢迎关注golang学习网公众号,带你了解更多关于的知识点!

相关阅读
更多>
最新阅读
更多>
课程推荐
更多>