xml-lexer

0.2.2 • Public • Published

XML-Lexer

Simple JavaScript Lexer for XML documents

Features

  • Very small, fast and simple! (~250 sloc)
  • Event driven API (SAX-like)
  • Works in Browser, WebWorkers, ServiceWorkers, Node.js or React Native
  • Fault tolerant
  • Handles CDATA
  • Easy to extend and fine tune (state machine is exposed in Lexer instances)

If you are looking for a XML Reader/Parser to convert XML documents into Javascript objects, check my other projects:

Install

npm install --save xml-lexer

Examples

Happy case

const lexer = require('xml-lexer').create();
 
const xml =
`<hello color="blue">
  <greeting>Hello, world!</greeting>
</hello>`;
 
lexer.on('data', (data) => console.log(data));
lexer.write(xml);
 
/*
Console output:
 
{ type: 'open-tag', value: 'hello' }
{ type: 'attribute-name', value: 'color' }
{ type: 'attribute-value', value: 'blue' }
{ type: 'open-tag', value: 'greeting' }
{ type: 'data', value: 'Hello, world!' }
{ type: 'close-tag', value: 'greeting' }
{ type: 'close-tag', value: 'hello' }
*/

Chunked processing

const lexer = require('xml-lexer').create();
 
const chunk1 = `<hello><greet`; // note this
const chunk2 = `ing>Hello, world!</greeting></hello>`;
 
lexer.on('data', (data) => console.log(data));
lexer.write(chunk1);
lexer.write(chunk2);
 
/*
Console output:
 
{ type: 'open-tag', value: 'hello' }
{ type: 'open-tag', value: 'greeting' }
{ type: 'data', value: 'Hello, world!' }
{ type: 'close-tag', value: 'greeting' }
{ type: 'close-tag', value: 'hello' }
*/

Document with errors

const lexer = require('xml-lexer').create();
 
lexer.on('data', (data) => console.log(data));
lexer.write(`<<hello">hi</hello attr="value">`);
 
/*
Console output (note the open-tag value):
 
{ type: 'open-tag', value: '<hello"' }
{ type: 'data', value: 'hi' }
{ type: 'close-tag', value: 'hello' }
*/

Update state machine to fix document errors

const Lexer = require('xml-lexer');
const lexer = Lexer.create();
 
lexer.stateMachine[Lexer.State.tagBegin][Lexer.Action.lt] = () => {};
lexer.stateMachine[Lexer.State.tagName][Lexer.Action.error] = () => {};
 
lexer.on('data', (data) => console.log(data));
lexer.write(`<<hello">hi</hello attr="value">`);
 
/*
Console output (note the fixed open-tag value):
 
{ type: 'open-tag', value: 'hello' }
{ type: 'data', value: 'hi' }
{ type: 'close-tag', value: 'hello' }
*/

License

MIT

Package Sidebar

Install

npm i xml-lexer

Weekly Downloads

82,401

Version

0.2.2

License

MIT

Last publish

Collaborators

  • pladaria