2016-11-03 01:33:53 +01:00
|
|
|
# xmlbuilder-js
|
|
|
|
|
2016-11-16 01:59:39 +01:00
|
|
|
An XML builder for [node.js](https://nodejs.org/) similar to
|
2016-11-03 01:33:53 +01:00
|
|
|
[java-xmlbuilder](https://github.com/jmurty/java-xmlbuilder).
|
|
|
|
|
|
|
|
[data:image/s3,"s3://crabby-images/8be46/8be4669d853ec40639e1d92d36906d100aaf637a" alt="License"](http://opensource.org/licenses/MIT)
|
|
|
|
[data:image/s3,"s3://crabby-images/f6795/f67953923891b6092494829918bd708c3f8b47b8" alt="NPM Version"](https://npmjs.com/package/xmlbuilder)
|
|
|
|
[data:image/s3,"s3://crabby-images/9a0af/9a0af0a406e7c1aa2d326674e4a8c3322f1a97eb" alt="NPM Downloads"](https://npmjs.com/package/xmlbuilder)
|
|
|
|
|
|
|
|
[data:image/s3,"s3://crabby-images/ccba5/ccba534bbce7146c3fd18adb564697691e898308" alt="Build Status"](http://travis-ci.org/oozcitak/xmlbuilder-js)
|
2016-11-16 01:59:39 +01:00
|
|
|
[data:image/s3,"s3://crabby-images/6deec/6deec140d0caba68f37f2471f5be7af690bbe8ca" alt="Dependency Status"](https://david-dm.org/oozcitak/xmlbuilder-js)
|
2016-11-03 01:33:53 +01:00
|
|
|
[data:image/s3,"s3://crabby-images/72988/729886ebc7ca1e92ee2bccda80680c997cefdaa7" alt="Dev Dependency Status"](https://david-dm.org/oozcitak/xmlbuilder-js)
|
|
|
|
[data:image/s3,"s3://crabby-images/96a2e/96a2e8815ff6ba70257c6a9096aa5d09cfe14cc1" alt="Code Coverage"](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});
|
2016-11-16 01:59:39 +01:00
|
|
|
|
2016-11-03 01:33:53 +01:00
|
|
|
console.log(xml);
|
|
|
|
```
|
|
|
|
|
|
|
|
will result in:
|
|
|
|
|
|
|
|
``` xml
|
|
|
|
<?xml version="1.0"?>
|
|
|
|
<root>
|
|
|
|
<xmlbuilder>
|
|
|
|
<repo type="git">git://github.com/oozcitak/xmlbuilder-js.git</repo>
|
|
|
|
</xmlbuilder>
|
|
|
|
</root>
|
|
|
|
```
|
|
|
|
|
|
|
|
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
|
|
|
|
<?xml version="1.0"?>
|
|
|
|
<squares>
|
|
|
|
<!-- f(x) = x^2 -->
|
|
|
|
<data x="1" y="1"/>
|
|
|
|
<data x="2" y="4"/>
|
|
|
|
<data x="3" y="9"/>
|
|
|
|
<data x="4" y="16"/>
|
|
|
|
<data x="5" y="25"/>
|
|
|
|
</squares>
|
|
|
|
```
|
|
|
|
|
|
|
|
See the [wiki](https://github.com/oozcitak/xmlbuilder-js/wiki) for details.
|