Skip to content

forOwn (Lodash 호환성)

Object.keys와 반복문을 사용하세요

forOwn 함수는 내부적으로 keys 함수를 호출하고 객체 변환 과정, null이나 undefined 처리 등으로 인해 느리게 동작해요.

대신 더 빠르고 현대적인 Object.keys와 반복문을 사용하세요.

객체의 고유 속성만 반복하면서 각 속성에 대해 함수를 호출해요.

typescript
const result = forOwn(obj, iteratee);

레퍼런스

forOwn(object, iteratee)

객체의 고유 속성만 반복하면서 iteratee 함수를 호출해요. 상속된 속성이나 Symbol 키는 제외하고 객체가 직접 소유한 속성만 반복해요. iteratee 함수가 false를 반환하면 반복을 중단해요.

typescript
import { forOwn } from 'es-toolkit/compat';

// 객체의 고유 속성만 반복
const obj = { a: 1, b: 2 };
forOwn(obj, (value, key) => {
  console.log(key, value);
});
// 출력: 'a' 1, 'b' 2

// 상속된 속성은 제외
function Parent() {
  this.inherited = 'value';
}
Parent.prototype.protoProperty = 'proto';

const child = new Parent();
child.own = 'ownValue';

forOwn(child, (value, key) => {
  console.log(key, value);
});
// 출력: 'inherited' 'value', 'own' 'ownValue' (protoProperty는 제외)

// 조건에 따른 조기 종료
forOwn(obj, (value, key) => {
  console.log(key, value);
  return key !== 'a'; // 'a' 이후 중단
});
// 출력: 'a' 1

null이나 undefined는 그대로 반환해요.

typescript
import { forOwn } from 'es-toolkit/compat';

forOwn(null, iteratee); // null
forOwn(undefined, iteratee); // undefined

파라미터

  • object (T | null | undefined): 반복할 객체예요.
  • iteratee ((value: T[keyof T], key: string, collection: T) => any, 선택): 각 속성에 대해 호출할 함수예요. 기본값은 identity 함수예요.

반환 값

(T | null | undefined): 원본 객체를 반환해요.

MIT 라이선스에 따라 배포됩니다.