|
|
|
# ≡
|
|
|
|
|
|
|
|
### isEq -- Deep-compare objects
|
|
|
|
|
|
|
|
`isEq` is a very tiny module that deep compares objects or arrays.
|
|
|
|
|
|
|
|
Although its intention is deep comparison, `isEq` can compare several datatypes.
|
|
|
|
|
|
|
|
## Supports
|
|
|
|
|
|
|
|
| Datatype | Support |
|
|
|
|
|--------------------- |--- |
|
|
|
|
| Number | ✅ |
|
|
|
|
| String | ✅ |
|
|
|
|
| Boolean | ✅ |
|
|
|
|
| Object | ✅ |
|
|
|
|
| Array | ✅ |
|
|
|
|
| Cyclic Object/Array | ✅ |
|
|
|
|
| Regexp | ✅ |
|
|
|
|
| Function | ✅ |
|
|
|
|
| Symbol | ✅ |
|
|
|
|
|
|
|
|
> Note: functions and symbols are compared by identity. Regexp is stringified before comparison.
|
|
|
|
> Unhandleable inputs fall back to strict equality (`===`)
|
|
|
|
|
|
|
|
## Installation
|
|
|
|
|
|
|
|
Node:
|
|
|
|
|
|
|
|
```Shell
|
|
|
|
npm install --save @codefeathers/iseq
|
|
|
|
```
|
|
|
|
|
|
|
|
In the browser:
|
|
|
|
```HTML
|
|
|
|
<script src="https://unpkg.com/@codefeathers/iseq">
|
|
|
|
```
|
|
|
|
|
|
|
|
## Usage
|
|
|
|
|
|
|
|
```JavaScript
|
|
|
|
isEq(<sourceObject>, <compareObject>, [comparisonKeys])
|
|
|
|
```
|
|
|
|
|
|
|
|
where if comparison keys are not given, `compareObject` is compared against all keys of `sourceObject`.
|
|
|
|
|
|
|
|
## Example
|
|
|
|
|
|
|
|
So you want to filter all the entities in `Steins;Gate` that have the property `isEvil: true`.
|
|
|
|
|
|
|
|
```JavaScript
|
|
|
|
var entities = [
|
|
|
|
{
|
|
|
|
name: 'Future Gadget Laboratory',
|
|
|
|
isEvil: false,
|
|
|
|
after: 'Disrupting the status quo',
|
|
|
|
"known-members": [
|
|
|
|
{ name: 'Okabe Rintarou', gender: 'Male', occupation: 'University student' },
|
|
|
|
{ name: 'Mayuri Shiina', gender: 'Female', occupation: 'Maid at May Queen' },
|
|
|
|
{ name: 'Itaru Hashida', gender: 'Male', occupation: 'Hacker' },
|
|
|
|
],
|
|
|
|
},
|
|
|
|
{
|
|
|
|
name: 'SERN',
|
|
|
|
isEvil: true,
|
|
|
|
after: 'IBN 5100',
|
|
|
|
"known-members": [
|
|
|
|
{ name: 'Yuugo Tennouji', gender: 'Male', occupation: 'CRT mechanic' },
|
|
|
|
{ name: 'Moeka Kiryū', gender: 'Female', occupation: 'Part-time editor' },
|
|
|
|
],
|
|
|
|
},
|
|
|
|
{
|
|
|
|
name: 'Strategic Focus',
|
|
|
|
isEvil: true,
|
|
|
|
after: 'Time travel',
|
|
|
|
"known-members": [
|
|
|
|
{ name: 'Alexis Leskinen', gender: 'Male', occupation: 'Professor' },
|
|
|
|
],
|
|
|
|
},
|
|
|
|
]
|
|
|
|
|
|
|
|
const evilEntities = entities.filter(eachEntity => isEq(eachEntity, { isEvil: true }, ['isEvil']));
|
|
|
|
```
|
|
|
|
<br><br>
|
|
|
|
|
|
|
|
***Written by [@MKRhere](https://mkr.pw)*** —
|