Huge News!Announcing our $40M Series B led by Abstract Ventures.Learn More
Socket
Sign inDemoInstall
Socket

equals

Package Overview
Dependencies
Maintainers
1
Versions
17
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

equals

Check if two values are deeply equivalent

  • 0.1.0
  • Source
  • npm
  • Socket score

Version published
Weekly downloads
48K
decreased by-51.34%
Maintainers
1
Weekly downloads
 
Created
Source

equals

Check if two values are equivalent. This is a deep equivalence check so if an object has other objects on it properties they must also be equivalent in order for the overall comparison to hold.

Getting Started

With component(1)

component install jkroso/equals --save

In Node.js

npm install equals --save

A pre-built browser version is also available. It exports the global variable equal.

API

var equal = require('equals')

deepEqual()

Values are considered equal if they could be swapped without consequence

equal(
  { a : [ 2, 3 ], b : [ 4 ] },
  { a : [ 2, 3 ], b : [ 4 ] }
) // => true
equal(
  { x : 5, y : [6] },
  { x : 5, y : 6 }
) // => false

Some possible gotchas:

  • null is not equal to undefined
  • NaN is equal to NaN (normally not the case in JS)
  • -0 is equal to +0
  • Strings will not coerce to numbers
  • Non enumerable properties will not be checked. (They can't be)
  • Arguments objects may differ on callee. Slice them first if you don't want to consider that

exports.object

If you already know the two things you are comparing are Object instances you can save processing time by calling this function directly. It doesn't matter what the objects contain internally as per the main function.

equal.object(
  {0:'first', 1: 'second'},
  ['first', 'second']
) // => true

For objects equivalence is determined by having the same number of enumerable properties, the same set of keys, and equivalent values for every key. Note: this accounts for both named and indexed properties on Arrays.

exports.all

Check that a sequence of values are equal

equal.all(1,1,1,1) // => true

Contributing

As with all my work this is both a work in progress and a thought in progress. Feel free to chip in in any way you can.

Release History

(Nothing yet)

Credit

A large part of this code was taken from node's assert module

License

Copyright (c) 2012 Jakeb Rosoman

Permission is hereby granted, free of charge, to any person obtaining a copy of this software and associated documentation files (the "Software"), to deal in the Software without restriction, including without limitation the rights to use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of the Software, and to permit persons to whom the Software is furnished to do so, subject to the following conditions:

The above copyright notice and this permission notice shall be included in all copies or substantial portions of the Software.

THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.

Keywords

FAQs

Package last updated on 12 Jan 2013

Did you know?

Socket

Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.

Install

Related posts

SocketSocket SOC 2 Logo

Product

  • Package Alerts
  • Integrations
  • Docs
  • Pricing
  • FAQ
  • Roadmap
  • Changelog

Packages

npm

Stay in touch

Get open source security insights delivered straight into your inbox.


  • Terms
  • Privacy
  • Security

Made with ⚡️ by Socket Inc