当前位置: 首页 > 知识库问答 >
问题:

javascript - js数据转换怎么搞?

贡光明
2023-05-05

下面数据格式有什么比较优雅的转换方式吗?
请各位大佬解惑

// 原始数据
let arr = [
    { name: '张三', age: 1 },
    { name: '李四', age: 1 },
    { name: '小红', age: 3 },
    { name: '明明', age: 3 },
    { name: '兰兰', age: 3 },
    { name: '红红', age: 4 },
    { name: '刘明', age: 4 },
    { name: '王五', age: 8 },
    { name: '麻子', age: 8 },
    { name: '瘸子', age: 8 },
]

// 目标数据
targetArr = [
    { 1: '张三', 3: '小红', 4: '红红', 8: '王五' },
    { 1: '李四', 3: '明明', 4: '刘明', 8: '麻子' },
    { 1: '', 3: '兰兰', 4: '', 8: '瘸子' },
]

共有1个答案

伏砚
2023-05-05
let arr = [
    { name: '张三', age: 1 },
    { name: '李四', age: 1 },
    { name: '小红', age: 3 },
    { name: '明明', age: 3 },
    { name: '兰兰', age: 3 },
    { name: '红红', age: 4 },
    { name: '刘明', age: 4 },
    { name: '王五', age: 8 },
    { name: '麻子', age: 8 },
    { name: '瘸子', age: 8 },
];

// 初始化目标数据结构
let temp = {};
arr.forEach(item => {
    if (!temp[item.age]) {
        temp[item.age] = [];
    }
    temp[item.age].push(item.name);
});

// 转换数据
let targetArr = [];
Object.values(temp).forEach(value => {
    value.forEach((name, index) => {
        if (!targetArr[index]) {
            targetArr[index] = {};
        }
        Object.keys(temp).forEach(key => {
            if (key in targetArr[index]) {
                return;
            }
            targetArr[index][key] = '';
        });
        targetArr[index][Object.keys(temp).find(key => temp[key] === value)] = name;
    });
});

console.log(targetArr);
 类似资料:
  • 上边格式如何转换为以下格式

  • 表格数据转换,后台返回的表格数据状态都是数字,所以前台需要转换一下。 后台返回的状态配置数据: 表格数据 根据状态配置数据使得前台表格展示相应的名称label。 我是怎么处理的呢,我对el-table进行二次分装,然后在处理数据转换 filterVal就是我分装的方法,但是封装的有问题,展示出来的还是数字

  • 想知道 js 字符串怎么转成数组对象,上面的转成下面的

  • 怎么转成 这用js怎么转成正确的数据。

  • 使用指南 - 数据报告 - 转化分析 - 怎么查看转化数据 设置完转化目标后,您可以在【转化概况】报告中查看转化数据,也可以在趋势、来源、推广等许多报告中查看细分维度的转化数据。 在报告中,点击“自定义指标”,勾选转化相关的指标,然后在报告列表右上角的下拉菜单中切换目标,如下图。

  • 要将这个数据: 转换成如下数据结构: 请教下如何实现?