kitchensink
Version:
Dispatch's awesome components and style guide
65 lines (51 loc) • 2.07 kB
Markdown
[![Build Status][3]][4]
[![dependency status][5]][6]
[![dev dependency status][7]][8]
[![License][license-image]][license-url]
[![Downloads][downloads-image]][downloads-url]
[![npm badge][11]][1]
[![browser support][9]][10]
Are these two values conceptually equal?
```js
var isEqual = require('is-equal');
var assert = require('assert');
var primitives = [true, false, undefined, 42, 'foo'];
primitives.forEach(function (primitive) {
assert.equal(isEqual(primitive, primitive), true);
});
assert.equal(isEqual(/a/g, /a/g));
assert.equal(isEqual(/a/g, new RegExp('a', 'g')));
assert.equal(isEqual({ a: 2 }, { a: 2 }), true);
assert.equal(isEqual([1, [2, 3], 4], [1, [2, 3], 4]), true);
var timestamp = Date.now();
assert.equal(isEqual(new Date(timestamp), new Date(timestamp)), true);
```
Will return an empty string if `isEqual` would return `true` - otherwise will return a non-empty string that hopefully explains the reasoning.
```
var whyNotEqual = require('is-equal/why');
assert.equal(whyNotEqual(1, 1), '');
assert.equal(
whyNotEqual({ a: 1 }, { a: 2 }),
'value at key "a" differs: numbers are different: 1 !== 2'
);
```
Simply clone the repo, `npm install`, and run `npm test`
[]: https://npmjs.org/package/is-equal
[]: http://versionbadg.es/ljharb/is-equal.svg
[]: https://travis-ci.org/ljharb/is-equal.svg
[]: https://travis-ci.org/ljharb/is-equal
[]: https://david-dm.org/ljharb/is-equal.svg
[]: https://david-dm.org/ljharb/is-equal
[]: https://david-dm.org/ljharb/is-equal/dev-status.svg
[]: https://david-dm.org/ljharb/is-equal#info=devDependencies
[]: https://ci.testling.com/ljharb/is-equal.png
[]: https://ci.testling.com/ljharb/is-equal
[]: https://nodei.co/npm/is-equal.png?downloads=true&stars=true
[]: http://img.shields.io/npm/l/is-equal.svg
[]: LICENSE
[]: http://img.shields.io/npm/dm/is-equal.svg
[]: http://npm-stat.com/charts.html?package=is-equal