@office-open/xml
v0.4.5
Published
XML parsing and serialization for Office Open XML. Zero dependencies, drop-in replacement for xml + xml-js.
Maintainers
Readme
@office-open/xml
XML parsing and serialization for Office Open XML. Zero dependencies, drop-in replacement for xml + xml-js.
Features
- Zero Dependencies - No external runtime dependencies, pure TypeScript implementation
- xml() Serialization - Drop-in replacement for the
xmlpackage - xml2js() Parsing - Drop-in replacement for
xml-jsXML parsing - js2xml() Stringifying - Drop-in replacement for
xml-jsJS-to-XML conversion - toElement() Direct Convert - Direct conversion from xml object format to xml-js Element, 10-19x faster than the xml→xml2js bridge
- Complete Type Definitions - Full type compatibility with
xmlandxml-js, import without changes - OOXML Optimized - Implements all options needed for Office Open XML document generation
Installation
# Install with npm
$ npm install @office-open/xml
# Install with pnpm
$ pnpm add @office-open/xmlMigration from xml + xml-js
Replace your existing imports:
// Before
import xml from "xml";
import { xml2js, js2xml } from "xml-js";
import type { Element } from "xml-js";
// After
import { xml, xml2js, js2xml } from "@office-open/xml";
import type { Element } from "@office-open/xml";No other code changes needed. All options and output formats are compatible.
Quick Start
import { xml, xml2js, js2xml, toElement } from "@office-open/xml";
// Serialize JS objects to XML
const xmlStr = xml({ "w:p": [{ _attr: { "w:val": "1" } }, { "w:r": [{ "w:t": "Hello" }] }] });
// <w:p w:val="1"><w:r><w:t>Hello</w:t></w:r></w:p>
// Parse XML to JS objects
const parsed = xml2js("<w:t>Hello</w:t>", { compact: false });
// Convert JS objects back to XML
const output = js2xml(parsed);
// Direct conversion (faster than xml → xml2js bridge)
const element = toElement({
"w:p": [{ _attr: { "w:val": "1" } }, { "w:r": [{ "w:t": "Hello" }] }],
});API
xml(input, options?)
Serialize JavaScript objects to XML string. Compatible with the xml package.
xml2js(xmlString, options?)
Parse XML string to JavaScript object. Compatible with xml-js.
js2xml(jsObject, options?)
Convert JavaScript object (xml-js Element format) to XML string. Compatible with xml-js.
json2xml(jsObject, options?)
Alias for js2xml.
xml2json(xmlString, options?)
Convenience function that returns JSON.stringify(xml2js(xmlString, options)).
toElement(input)
Direct conversion from xml object format to xml-js Element format. Much faster than the xml() → xml2js() bridge path.
escapeXml(str) / escapeAttributeValue(str)
Low-level XML entity escaping functions.
Benchmark
Performance comparison against original xml (1.0.1) and xml-js (1.6.11) packages:
Serialization (xml)
| Scenario | @office-open/xml | xml | Speedup | | ----------------------- | ---------------: | ---------: | --------: | | Simple element | 4,023,269 hz | 742,728 hz | 5.42x | | Nested element | 1,030,612 hz | 322,801 hz | 3.19x | | Nested with declaration | 963,725 hz | 276,547 hz | 3.49x |
Parsing (xml2js)
| Scenario | @office-open/xml | xml-js | Speedup | | ------------------ | ---------------: | --------: | ---------: | | Simple XML | 1,147,347 hz | 95,579 hz | 12.00x | | Complex OOXML | 401,553 hz | 52,327 hz | 7.67x | | With captureSpaces | 387,082 hz | 52,317 hz | 7.40x |
Stringifying (js2xml)
| Scenario | @office-open/xml | xml-js | Speedup | | -------------- | ---------------: | ---------: | --------: | | Simple element | 778,368 hz | 197,520 hz | 3.94x | | Complex OOXML | 344,376 hz | 127,493 hz | 2.70x |
Direct Conversion (toElement vs bridge)
| Scenario | toElement() | xml() + xml2js() bridge | Speedup | | -------- | ------------: | ----------------------: | ---------: | | Simple | 14,953,390 hz | 803,917 hz | 18.61x | | Nested | 4,530,626 hz | 466,126 hz | 9.72x |
Bundle Size
| | @office-open/xml | xml + xml-js | | ---- | ---------------: | -----------: | | gzip | 4.22 kB | ~15 kB |
