Справочная информация: код предварительной обработки будет выполняться на большом количестве данных для извлечения свойств, которые необходимо отобразить на диаграмме. Диаграмма представляет собой параллельную координатную диаграмму. Он будет работать в браузере.
Фрагмент: извлекает измененные свойства и связанную категорию
Мой фрагмент выводит ответ правильно, но не эффективно
var all = [
{
Dim_A: { v: '0', category: 'Window' },
Dim_B: { v: '-1', category: 'Wall' },
Dim_C: { v: '0', category: 'Wall' },
Dim_D: { v: '0', category: 'Exterior Wall' }
},
{
Dim_A: { v: '0', category: 'Window' },
Dim_B: { v: '2', category: 'Wall' },
Dim_C: { v: '1', category: 'Wall' },
Dim_D: { v: '0', category: 'Exterior Wall' }
},
{
Dim_A: { v: '0', category: 'Window' },
Dim_B: { v: '-1', category: 'Wall' },
Dim_C: { v: '0', category: 'Wall' }
},
{
Dim_A: { v: '0', category: 'Window' },
Dim_B: { v: '-1', category: 'Wall' },
Dim_C: { v: '0', category: 'Wall' },
Dim_E: { v: '0', category: 'Exterior Wall' }
}
]
if (all.length < 2) {
throw 'need at least 2'
}
let distinctDims = new Map()
for (let i = 0; i < all.length - 1; i++) {
for (let j = i + 1; j < all.length; j++) {
if (i === j) {
continue
}
let a = all[i]
let b = all[j]
for (let pa in a) {
if (!a[pa] || !b[pa] || a[pa].v !== b[pa].v)
distinctDims[pa] = { category: a[pa].category }
}
for (let pb in b) {
if (!a[pb] || !b[pb] || a[pb].v !== b[pb].v)
distinctDims[pb] = { category: b[pb].category }
}
}
}
console.log(distinctDims)
Выводится правильно. Ищем более эффективный способ.