吾爱破解 - 52pojie.cn

 找回密码
 注册[Register]

QQ登录

只需一步,快速开始

查看: 689|回复: 4
收起左侧

[学习记录] JS 数组根据某一字段值分组

[复制链接]
lucklys 发表于 2022-8-15 14:40
本帖最后由 lucklys 于 2022-8-15 15:45 编辑

[JavaScript] 纯文本查看 复制代码
[{id:1,name:'大'}, {id:2,name:'小'}, {id:3,name:'大'}, {id:4,name:'小'}, {id:5,name:'大'}, {id:6,name:'大'}, {id:7,name:'小'}, {id:7,name:'中'}, {id:7,name:'小'}, {id:7,name:'中'}]

比如我有一组数据 是这样子的,可能还会有超大 超小 之类的
我需要 把相同的name 放到一块
我该怎么做呀,整不会了。

[JavaScript] 纯文本查看 复制代码
let a = [
	{ id: 1, name: '大' },
	{ id: 2, name: '小' },
	{ id: 3, name: '大' },
	{ id: 4, name: '小' },
	{ id: 5, name: '大' },
	{ id: 6, name: '大' },
	{ id: 7, name: '小' },
	{ id: 7, name: '中' },
	{ id: 7, name: '小' },
	{ id: 7, name: '中' },
]
let newArr = []
let nameList = new Set(a.map(item => item.name))
nameList.forEach((item, index) => {
	newArr[index] = {
		name: item,
		goods: [],
	}
	a.forEach(items => {
		if (item == items.name) {
			newArr[index].goods.push(items)
		}
	})
})
console.log(newArr)

我自己想到这这种解决方法,还有更简单的吗~

发帖前要善用论坛搜索功能,那里可能会有你要找的答案或者已经有人发布过相同内容了,请勿重复发帖。

RenGuiSong 发表于 2022-8-15 14:45
百度,js groupBy方法  一大堆的
52P 发表于 2022-8-15 14:48
52P 发表于 2022-8-15 14:58
[JavaScript] 纯文本查看 复制代码
const arr = [
    { id: 1, name: '大' },
    { id: 2, name: '小' },
    { id: 3, name: '大' },
    { id: 4, name: '小' },
    { id: 5, name: '大' },
    { id: 6, name: '大' },
    { id: 7, name: '小' },
    { id: 7, name: '中' },
    { id: 7, name: '小' },
    { id: 7, name: '中' }
]

const newarr = arr.reduce(function (pre, cur) {
    const item = pre.find(p => p.name == cur.name)
    if (item) {
        item.data.push(cur)
    } else {
        pre.push({
            name: cur.name,
            data: [cur]
        })
    }
    return pre
}, [])

const ids = arr.reduce(function (pre, cur) {
    if (pre[cur.id]) {
        pre[cur.id].push(cur)
    } else {
        pre[cur.id] = [cur]
    }
    return pre
}, {})

console.log(JSON.stringify(newarr, null, 4))
console.log(JSON.stringify(ids, null, 4))
 楼主| lucklys 发表于 2022-8-15 15:19
52P 发表于 2022-8-15 14:58
[mw_shl_code=javascript,true]const arr = [
    { id: 1, name: '大' },
    { id: 2, name: '小' },

牛啊,我从来都没用过这东西
您需要登录后才可以回帖 登录 | 注册[Register]

本版积分规则

返回列表

RSS订阅|小黑屋|处罚记录|联系我们|吾爱破解 - LCG - LSG ( 京ICP备16042023号 | 京公网安备 11010502030087号 )

GMT+8, 2024-11-25 07:44

Powered by Discuz!

Copyright © 2001-2020, Tencent Cloud.

快速回复 返回顶部 返回列表