isEqual (Lodash互換性)
es-toolkitのisEqualを使用してください
このisEqual関数はLodash互換性のための複雑な処理により動作が遅くなります。
代わりに、より速く現代的なes-toolkitのisEqualを使用してください。
二つの値が同じかどうかを深く比較して確認します。
typescript
const result = isEqual(value1, value2);参照
isEqual(a, b)
二つの値が同じかどうかを深く比較して確認したい場合はisEqualを使用してください。Date、RegExp、オブジェクト、配列などの複雑な型も内容まで比較します。
typescript
import { isEqual } from 'es-toolkit/compat';
// 基本型の比較
isEqual(1, 1); // true
isEqual('hello', 'hello'); // true
isEqual(true, true); // true
// オブジェクトの深い比較
isEqual({ a: 1, b: 2 }, { a: 1, b: 2 }); // true
isEqual({ a: 1, b: 2 }, { b: 2, a: 1 }); // true
isEqual({ a: 1 }, { a: 1, b: undefined }); // false
// 配列の深い比較
isEqual([1, 2, 3], [1, 2, 3]); // true
isEqual([1, [2, 3]], [1, [2, 3]]); // true
// Dateオブジェクトの比較
isEqual(new Date('2020-01-01'), new Date('2020-01-01')); // true
isEqual(new Date('2020-01-01'), new Date('2020-01-02')); // false
// RegExpオブジェクトの比較
isEqual(/abc/g, /abc/g); // true
isEqual(/abc/g, /abc/i); // falseネストされたオブジェクトや配列も再帰的に比較します。
typescript
import { isEqual } from 'es-toolkit/compat';
const obj1 = {
user: {
name: 'John',
details: {
age: 30,
hobbies: ['reading', 'gaming'],
},
},
};
const obj2 = {
user: {
name: 'John',
details: {
age: 30,
hobbies: ['reading', 'gaming'],
},
},
};
isEqual(obj1, obj2); // trueパラメータ
a(unknown): 比較する最初の値です。b(unknown): 比較する2番目の値です。
戻り値
(boolean): 二つの値が同じ場合はtrue、異なる場合はfalseを返します。

