A posthtml plugin to beautify you html files
Format your html and inline css markup according to the HTML5 syntax Style Guide, Code Guide. Full list of supported options:
- Transform lower case element names
 - Transform lower case attribute names
 - Only double quotes
 - Close all html elements
 - Removing trailing slash in self-closing
 - Removes spaces at the equal sign
 - Add blank lines to separate large or logical code blocks
 - Add 2 spaces of indentation. Do not use TAB.
 - Add language attribute
 - Add character encoding
 - Attribute order
 - Boolean attributes
 - Creates file from the inline styles
 - Create scoped class name (use css-modules) instead inline styles
 - validate elements and attributes name
 - parses Internet Explorer Conditional Comments (not support Downlevel-revealed and valid version, htmlparse2 invalid parses)
 
npm i -S posthtml posthtml-beautifyNote: This project is compatible with node v10+
import {readFileSync, writeFileSync} from 'fs';
import posthtml from 'posthtml';
import beautify from 'posthtml-beautify';
const html = readFileSync('input.html', 'utf8');
posthtml()
  .use(beautify({rules: {indent: 4}}))
  .process(html)
  .then(result => {
    writeFileSync('output.html', result.html);
  });Returns html-formatted according to rules based on the use HTML5 syntax Style Guide, Code Guide with custom settings indent: 4
Type: Object
Default:
- 
Indent
Type:Number|String(only tab)
Default: 2
Description: A numeric value indicates specifies the number of spaces. The string value onlytab - 
blankLines
Type:String|Boolean(only false)
Default: '\n'
Description: Add or remove blank lines to separate large or logical code blocks - 
eol (end of line)
Type:String
Default: '\n'
Description: As value is a string symbol which is added to the end of the row - 
eof (end of file)
Type:String|Boolean
Default: '\n'
Description: As value is a string symbol which is added to the end of the file and will not adds if you specify a boolean value offalse - 
maxlen
Type:Number
Default: '80'
Description: checks for the max length of the content, indents the whole content to a new line - 
sortAttr
Type:Boolean
Default: false
Description: Sort the order of attributes in elements - 
lang
Type:String | Boolean(only false)
Default: false
Description: Add alangattribute in elements, eg:{ lang: 'fr' } - 
commentFormat
Type:Boolean
Default: true
Description: Formats the comments. It does the following- 
If there are multi line comments then there would be leading and trailing newline like this
// Input <!-- multiline comments--> // Output <!-- multiline comments -->
 - 
If there is a single line comment, it would make it to a single line with the comment starting and ending notation in same line
Input
<!-- singleline comments -->Output
<!-- singleline comments --> 
 - 
 
Type: Object
Default:
- removeAttribute
Type:String|Boolean
Default: false
Description: Removes attributes that do not matter. The string value onlyempty 
Type: Object
Default: All options as per package js-beautify except, indent_level because calculated and set according to context
- js-beautify - Beautifier for javascript