
Security News
Vite+ Joins the Push to Consolidate JavaScript Tooling
Evan You announces Vite+, a commercial, Rust-powered toolchain built on the Vite ecosystem to unify JavaScript development and fund open source.
@codefeathers/iseq
Advanced tools
isEq
is a very tiny module that deep compares objects or arrays.
Although its intention is deep comparison, isEq
can compare several datatypes.
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 (
===
)
Node:
npm install --save @codefeathers/iseq
In the browser:
<script src="https://unpkg.com/@codefeathers/iseq">
isEq(<sourceObject>, <compareObject>, [comparisonKeys])
where if comparison keys are not given, compareObject
is compared against all keys of sourceObject
.
So you want to filter all the entities in Steins;Gate
that have the property isEvil: true
.
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']));
Written by @MKRhere —
FAQs
Deep compare objects and arrays
We found that @codefeathers/iseq demonstrated a not healthy version release cadence and project activity because the last version was released a year ago. It has 1 open source maintainer collaborating on the project.
Did you know?
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.
Security News
Evan You announces Vite+, a commercial, Rust-powered toolchain built on the Vite ecosystem to unify JavaScript development and fund open source.
Security News
Ruby Central’s incident report on the RubyGems.org access dispute sparks backlash from former maintainers and renewed debate over project governance.
Research
/Security News
Socket researchers uncover how threat actors weaponize Discord across the npm, PyPI, and RubyGems ecosystems to exfiltrate sensitive data.