# xmlbuilder-js
An XML builder for [node.js](https://nodejs.org/) similar to
[java-xmlbuilder](https://github.com/jmurty/java-xmlbuilder).
[](http://opensource.org/licenses/MIT)
[](https://npmjs.com/package/xmlbuilder)
[](https://npmjs.com/package/xmlbuilder)
[](http://travis-ci.org/oozcitak/xmlbuilder-js)
[](https://ci.appveyor.com/project/oozcitak/xmlbuilder-js)
[](https://david-dm.org/oozcitak/xmlbuilder-js)
[](https://coveralls.io/github/oozcitak/xmlbuilder-js)
### Installation:
``` sh
npm install xmlbuilder
```
### Usage:
``` js
var builder = require('xmlbuilder');
var xml = builder.create('root')
  .ele('xmlbuilder')
    .ele('repo', {'type': 'git'}, 'git://github.com/oozcitak/xmlbuilder-js.git')
  .end({ pretty: true});
console.log(xml);
```
will result in:
``` xml
  
    git://github.com/oozcitak/xmlbuilder-js.git
  
```
It is also possible to convert objects into nodes:
``` js
builder.create({
  root: {
    xmlbuilder: {
      repo: {
        '@type': 'git', // attributes start with @
        '#text': 'git://github.com/oozcitak/xmlbuilder-js.git' // text node
      }
    }
  }
});
```
If you need to do some processing:
``` js
var root = builder.create('squares');
root.com('f(x) = x^2');
for(var i = 1; i <= 5; i++)
{
  var item = root.ele('data');
  item.att('x', i);
  item.att('y', i * i);
}
```
This will result in:
``` xml
  
  
  
  
  
  
```
See the [wiki](https://github.com/oozcitak/xmlbuilder-js/wiki) for details and [examples](https://github.com/oozcitak/xmlbuilder-js/wiki/Examples) for more complex examples.