下面数据格式有什么比较优雅的转换方式吗?
请各位大佬解惑
// 原始数据
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: '瘸子' },
]
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怎么转成正确的数据。
使用指南 - 数据报告 - 转化分析 - 怎么查看转化数据 设置完转化目标后,您可以在【转化概况】报告中查看转化数据,也可以在趋势、来源、推广等许多报告中查看细分维度的转化数据。 在报告中,点击“自定义指标”,勾选转化相关的指标,然后在报告列表右上角的下拉菜单中切换目标,如下图。
要将这个数据: 转换成如下数据结构: 请教下如何实现?