lhl 2bdf874dbb create 1 month ago
..
test 2bdf874dbb create 1 month ago
.eslintrc 2bdf874dbb create 1 month ago
.nycrc 2bdf874dbb create 1 month ago
CHANGELOG.md 2bdf874dbb create 1 month ago
LICENSE 2bdf874dbb create 1 month ago
README.md 2bdf874dbb create 1 month ago
auto.js 2bdf874dbb create 1 month ago
implementation.js 2bdf874dbb create 1 month ago
index.js 2bdf874dbb create 1 month ago
package.json 2bdf874dbb create 1 month ago
polyfill.js 2bdf874dbb create 1 month ago
shim.js 2bdf874dbb create 1 month ago

README.md

object-is Version Badge

github actions coverage License Downloads

npm badge

ES2015-compliant shim for Object.is - differentiates between -0 and +0, and can compare to NaN.

Essentially, Object.is returns the same value as === - but true for NaN, and false for -0 and +0.

This package implements the es-shim API interface. It works in an ES3-supported environment and complies with the spec.

Example

Object.is = require('object-is');
var assert = require('assert');

assert.ok(Object.is());
assert.ok(Object.is(undefined));
assert.ok(Object.is(undefined, undefined));
assert.ok(Object.is(null, null));
assert.ok(Object.is(true, true));
assert.ok(Object.is(false, false));
assert.ok(Object.is('foo', 'foo'));

var arr = [1, 2];
assert.ok(Object.is(arr, arr));
assert.equal(Object.is(arr, [1, 2]), false);

assert.ok(Object.is(0, 0));
assert.ok(Object.is(-0, -0));
assert.equal(Object.is(0, -0), false);

assert.ok(Object.is(NaN, NaN));
assert.ok(Object.is(Infinity, Infinity));
assert.ok(Object.is(-Infinity, -Infinity));

Tests

Simply clone the repo, npm install, and run npm test