html-differ
Compares two HTML.
The comparison algorithm
html-differ compares HTML using the following criteria:
<!DOCTYPE>
declarations are case-insensitive, so the following two code samples will be considered to be equivalent:
- Whitespaces (spaces, tabs, new lines etc.) inside start and end tags are ignored during the comparison.
For example, the following two code samples will be considered to be equivalent:
- Two respective lists of attributes are considered to be equivalent even if they are specified in different order.
For example, the following two code samples will be considered to be equivalent:
Text
Text
- Two respective attributes
class
are considered to be equivalent if they refer to the same groups of CSS styles.
For example, the following two code samples will be considered to be equivalent:
Text
Text
CAUTION!
html-differ does not check the validity of HTML, but compares them using the above shown criteria and specified options (see the list of possible options).
Install
$ npm install html-differ
API
HtmlDiffer
var HtmlDiffer = HtmlDiffer htmlDiffer = options;
where options
is an object.
Options
ignoreAttributes: [Array]
Sets what kind of respective attributes' content will be ignored during the comparison (default: []
).
Example: ['id', 'for']
The following two code samples will be considered to be equivalent:
Text
Text
compareAttributesAsJSON: [Array]
Sets what kind of respective attributes' content will be compared as JSON objects, but not as strings (default: []
).
In cases when the value of the attribute is an invalid JSON or can not be wrapped into a function, it will be compared as undefined
.
Example: [{ name: 'data', isFunction: false }, { name: 'onclick', isFunction: true }]
The following two code samples will be considered to be equivalent:
REMARK!
The first element of the array could be written in a short form as string:
['data', { name: 'onclick', isFunction: true }]
.
ignoreWhitespaces: Boolean
Makes html-differ ignore whitespaces (spaces, tabs, new lines etc.) during the comparison (default: true
).
Example: true
The following two code samples will be considered to be equivalent:
Text TextText
Text Text Text
ignoreComments: Boolean
Makes html-differ ignore HTML comments during the comparison (default: true
).
REMARK!
Does not ignore conditional comments.
Example: true
The following two code samples will be considered to be equivalent:
<!-- comments1 --> <!--[if IE]> <link rel="stylesheet" type="text/css" href="all-ie-only.css" /> <![endif]--> <!--[if !IE]><!--> <!--<![endif]-->Text<!-- comments2 -->
<!--[if IE]> <link href="all-ie-only.css" type="text/css" rel="stylesheet"/> <![endif]--> <!--[if !IE]><!--> <!--<![endif]-->Text
ignoreEndTags: Boolean
Makes html-differ ignore end tags during the comparison (default: false
).
Example: true
The following two code samples will be considered to be equivalent:
Text
Text
ignoreDuplicateAttributes: Boolean
Makes html-differ ignore tags' duplicate attributes during the comparison.
From the list of the same tag's attributes, the attribute which goes the first will be taken for comparison, others will be ignored (default: false
).
Example: true
For example, the following two code samples will be considered to be equivalent:
Text
Text
Presets
Usage
Passing of a preset via the constructor:
var HtmlDiffer = HtmlDiffer htmlDiffer = 'bem';
Redefinition of a preset via the constructor:
var HtmlDiffer = HtmlDiffer htmlDiffer = preset: 'bem' ignoreAttributes: ;
Methods
htmlDiffer.diffHtml
@param {String} - the 1-st HTML code
@param {String} - the 2-nd HTML code
@returns {Array of objects} - array with diffs between HTML
htmlDiffer.isEqual
@param {String} - the 1-st HTML code
@param {String} - the 2-nd HTML code
@returns {Boolean}
Logger
var logger = ;
Methods
logger.getDiffText
@param {Array of objects} - the result of the work of the method htmlDiffer.diffHtml
@param {Object} - options:
- charsAroundDiff: Number - the number of characters around the diff result between two HTML (default:
40
).
@returns {String}
logger.logDiffText
@param {Array of objects} - the result of the work of the method htmlDiffer.diffHtml
@param {Object} - options:
- charsAroundDiff: Number - the number of characters around the diff result between two HTML (default:
40
).
@returns - pretty logging of diffs:
Example
var fs = HtmlDiffer = HtmlDiffer logger = ; var html1 = fs html2 = fs; var options = ignoreAttributes: compareAttributesAsJSON: ignoreWhitespaces: true ignoreComments: true ignoreEndTags: false ignoreDuplicateAttributes: false ; var htmlDiffer = options; var diff = htmlDiffer isEqual = htmlDiffer res = logger; logger;
Usage as a program
$ html-differ --helpCompares two HTML Usage: html-differ [OPTIONS] [ARGS] Options: -h, --help : Help -v, --version : Shows the version number --config=CONFIG : Path to a configuration JSON file --bem : Uses predefined options
Example
$ html-differ path/to/html1 path/to/html2 $ html-differ --config=path/to/config --chars-around-diff=40 path/to/html1 path/to/html2 $ html-differ --preset=bem path/to/html1 path/to/html2
Configuration file
Study the following file config.json
:
"ignoreAttributes": "compareAttributesAsJSON": "ignoreWhitespaces": true "ignoreComments": true "ignoreEndTags": false "ignoreDuplicateAttributes": false
Masks
html-differ supports handling of masks in HTML.
For example, the following two code samples will be considered to be equivalent:
Syntax
Masks in html-differ have the following syntax:
RegExp
where:
-
{{
– opening identifier of the mask. -
RegExp
– regular expression for matching with the corresponding value in another HTML. The syntax is similar to regular expressions in JavaScript written in a literal notation. -
}}
– closing identifier of the mask.
Screening
The rules of screening of symbols are similar to the rules which are used in regular expressions in JavaScript written in a literal notation.
For example, the following two code samples will be considered to be equivalent:
If you want to use {{
or }}
inside a mask, you should screen both curly braces, i.e. \{\}
or \}\}
.
For example, the following two code samples will be considered to be equivalent: