не указаны свои заголовки,
* то в качестве заголовков используются ключи первого в массиве объекта.
* Значения в строках расставляются в последовательности соответствующей заголовку.
* Если флаг options.includeHeader установлен в значение true, то первой строкой является значение заголовков
* @param {Array<object>} collection - массив объектов, которые будут преобразованы в строки
* @param {{ ownHeaders?: Array<string>; includeHeader: boolean }} options
* @param {string[]} [options.ownHeaders] - массив, последовательность заголовков
* @param {boolean} [options.includeHeader] - включить строку заголовков в результат
* @returns {Array<Array<(string|number|boolean)>>} массив массивов (строк)
*/
function collectionToGrid(collection, options) {
const includeHeader = options?.includeHeader === true ? true : false;
const headers = options?.ownHeaders || Object.keys(collection[0]);
const grid = collection.map((obj) => {
const row = [];
for (const header of headers) {
row.push(obj[header] || '');
}
return row;
});
if (includeHeader === true) {
return [headers, ...grid];
}
return grid;
}
А над этим сейчас поразмыслю, сходу не понял) Спасибо!
Обсуждают сегодня