Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/dashed/shallowequal
↔️ Like lodash v3.x isEqualWith but for shallow equal.
https://github.com/dashed/shallowequal
comparison equality javascript shallow-equal shallowequal utility
Last synced: about 16 hours ago
JSON representation
↔️ Like lodash v3.x isEqualWith but for shallow equal.
- Host: GitHub
- URL: https://github.com/dashed/shallowequal
- Owner: dashed
- License: mit
- Created: 2015-06-12T13:48:04.000Z (over 9 years ago)
- Default Branch: master
- Last Pushed: 2021-10-18T19:00:09.000Z (about 3 years ago)
- Last Synced: 2025-01-05T04:09:48.523Z (8 days ago)
- Topics: comparison, equality, javascript, shallow-equal, shallowequal, utility
- Language: JavaScript
- Homepage:
- Size: 1.03 MB
- Stars: 172
- Watchers: 5
- Forks: 16
- Open Issues: 13
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# shallowequal [![Build Status](https://travis-ci.org/dashed/shallowequal.svg)](https://travis-ci.org/dashed/shallowequal) [![Downloads](https://img.shields.io/npm/dm/shallowequal.svg)](https://npmjs.com/shallowequal) [![npm version](https://img.shields.io/npm/v/shallowequal.svg?style=flat)](https://www.npmjs.com/package/shallowequal)
> `shallowequal` is like lodash's [`isEqual`](https://lodash.com/docs/3.10.1#isEqual) (v3.10.1) but for shallow (strict) equal.
`shallowequal(value, other, [customizer], [thisArg])`
Performs a **_shallow equality_** comparison between two values (i.e. `value` and `other`) to determine if they are equivalent.
The equality check returns true if `value` and `other` are already strictly equal, OR when all the following are true:
- `value` and `other` are both objects with the same keys
- For each key, the value in `value` and `other` are **strictly equal** (`===`)If `customizer` (expected to be a function) is provided it is invoked to compare values. If `customizer` returns `undefined` (i.e. `void 0`), then comparisons are handled by the `shallowequal` function instead.
The `customizer` is bound to `thisArg` and invoked with three arguments: `(value, other, key)`.
**NOTE:** Docs are (shamelessly) adapted from [lodash's v3.x docs](https://lodash.com/docs/3.10.1#isEqual)
## Install
```sh
$ yarn add shallowequal
# npm v5+
$ npm install shallowequal
# before npm v5
$ npm install --save shallowequal
```## Usage
```js
const shallowequal = require("shallowequal");const object = { user: "fred" };
const other = { user: "fred" };object == other;
// → falseshallowequal(object, other);
// → true
```## Credit
Code for `shallowEqual` originated from https://github.com/gaearon/react-pure-render/ and has since been refactored to have the exact same API as `lodash.isEqualWith` (as of `v4.17.4`).
## Development
- `node.js` and `npm`. See: https://github.com/creationix/nvm#installation
- `yarn`. See: https://yarnpkg.com/en/docs/install
- `npm` dependencies. Run: `yarn install`### Chores
- Lint: `yarn lint`
- Test: `yarn test`
- Pretty: `yarn pretty`
- Prepare: `yarn prepare`## License
MIT.