# htmlparser2
[data:image/s3,"s3://crabby-images/775b7/775b7b5743ad11cd5fb48acbfa6c2fc78e300dc8" alt="NPM version"](https://npmjs.org/package/htmlparser2)
[data:image/s3,"s3://crabby-images/6151b/6151bf603a8da706009d27d47d9655ac9a835331" alt="Downloads"](https://npmjs.org/package/htmlparser2)
[data:image/s3,"s3://crabby-images/93e5d/93e5d149736db23322a067549e473aba99ca881a" alt="Build Status"](http://travis-ci.org/fb55/htmlparser2)
[data:image/s3,"s3://crabby-images/1a710/1a7104ffc4e7c51dd4775637c532ee46b7de0879" alt="Coverage"](https://coveralls.io/r/fb55/htmlparser2)
A forgiving HTML/XML/RSS parser. The parser can handle streams and provides a callback interface.
## Installation
npm install htmlparser2
A live demo of htmlparser2 is available [here](https://astexplorer.net/#/2AmVrGuGVJ).
## Usage
```javascript
var htmlparser = require("htmlparser2");
var parser = new htmlparser.Parser({
onopentag: function(name, attribs){
if(name === "script" && attribs.type === "text/javascript"){
console.log("JS! Hooray!");
}
},
ontext: function(text){
console.log("-->", text);
},
onclosetag: function(tagname){
if(tagname === "script"){
console.log("That's it?!");
}
}
}, {decodeEntities: true});
parser.write("Xyz