qweezz
qweezz

Reputation: 804

How to get XML from array of objects with xml2js?

I want to use xml2js to build XML file from array of objects. Is there a way to do it?

This doen't work because xml2js.Builder() expects a single object.

export const buildXML = (data: any[]) => {
  const builder = new xml2js.Builder();
  return builder.buildObject(data)
}

This returns array of XMLs but I need a single one:

export const buildXML = (data: any[]) => {
  const builder = new xml2js.Builder();
  return data.map(obj => builder.buildObject(obj))
}

The resulted XML should be used in this function

export const downloadFile = (data: any[], fileName = 'generator_result', fileFormat: any) => {
  let parsedData: any
  const FILE_TYPE = fileFormat === 'xml' ? XML_TYPE : EXCEL_TYPE;
  if (fileFormat === 'xml') {
    parsedData = buildXML(data);
  } else {
    parsedData = downloadAsExcel(data, fileFormat)
  }
  const fileData = new Blob([parsedData], {type: FILE_TYPE});
  saveAs(fileData, fileName + '.' + fileFormat);
}

UPD If I do this then nothing happens...I mean no console.log(x)...this means that something is wrong in line const x = builder.buildObject(data) isn't it?

export const buildXML = (data: any[]) => {
  const builder = new xml2js.Builder();
  const x = builder.buildObject(data)
  console.log('x:', x)
  return x
}

Upvotes: 0

Views: 2242

Answers (1)

lbsn
lbsn

Reputation: 2402

You can just pass your array to the builder:

const data = [{ item: '1' }, { item: '2' }, { item: '3' }];
const buildXML = (data) => {
  const builder = new xml2js.Builder();
  return builder.buildObject(data);
};
const doc = buildXML(data);

Since XML must have a root element xml2js will add it for you producing this result:

<?xml version="1.0" encoding="UTF-8" standalone="yes"?>
<root>
  <item>1</item>
  <item>2</item>
  <item>3</item>
</root>

If you'd like to have more control about the root element just wrap your array in a parent object with a single property (property's name will become the root element):

const data = {data: [{ item: '1' }, { item: '2' }, { item: '3' }]};
const buildXML = (data) => {
  const builder = new xml2js.Builder();
    return builder.buildObject(data);
  };
const doc = buildXML(data);

Result:

<?xml version="1.0" encoding="UTF-8" standalone="yes"?>
<data>
  <item>1</item>
  <item>2</item>
  <item>3</item>
</data>

Upvotes: 1

Related Questions